
<!DOCTYPE HTML>
<html lang="zh-hans" >
<head>
    <meta charset="UTF-8">
    <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
    <title>1.3：搭建Flutter开发环境 · 《Flutter实战》</title>
    <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
    <meta name="baidu-site-verification" content="Y34sAqDKUH"/>
    <meta name="theme-color" content="#ffffff">
    <!--<meta name="description" content="">-->
    <meta name="description" content="《Flutter实战》是Flutter中文网（https://flutterchina.club）开源的电子书，旨在帮助开发者系统化的了解并学习Flutter。">
    <meta name="keywords" content="flutter实战,flutter书籍,flutter电子书,flutter中文网 ">
    <meta name="generator" content="GitBook 3.2.3">
    
    <meta name="author" content="wendux 824783146@qq.com">
    
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/style.css">

    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-search-pro/search.css">
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-ace/ace.css">
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-splitter/splitter.css">
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-prism/prism.css">
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-donate/plugin.css">
    
    
    
    <link rel="stylesheet" href="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-fontsettings/website.css">
    
    
    

    

    
        
    
        
    
        
    
        
    
        
    

    
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="https://pcdn.flutterchina.club/gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="https://pcdn.flutterchina.club/gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="dart.html" />
    
    
    <link rel="prev" href="flutter_intro.html" />
    

    <style>
        .pull-right > i {
            font-size: 25px;
            color: #777 !important;
            cursor: pointer;

        }

        .pull-right > i:hover {
            color: #777 !important;
        }

        body {
            font-size: 15px !important;
        }

        a[href='../todo.html'], a[href='todo.html'] {
            color: #888 !important;
        }

        .copyright {
            text-align: center;
            margin: 80px 16px 8px 16px;
            padding-top: 16px;
            border-top: #eee 1px solid;
            color: grey;
            font-size: .9em;
        }

        .f-links a{
            text-decoration: underline;
            color: dodgerblue !important;
        }

        .f-links a:hover{
            opacity: .8 !important;
        }

        /*.ad {*/
            /*color: white;*/
            /*text-align: center;*/
            /*background: url(https://img.alicdn.com/tfs/TB1Huu7vMmTBuNjy1XbXXaMrVXa-2880-400.png);*/
            /*background-size: cover;*/
            /*cursor: pointer;*/
            /*margin-bottom: 30px;*/
            /*padding: 18px*/
        /*}*/

        /*.ad:hover {*/
            /*opacity: .8;*/
        /*}*/

        .buy-btn {
            text-decoration: none !important;
            padding: 8px 18px;
            border: #268bd2 1px solid !important;
            display: inline-block !important;
            border-radius: 25px;
            color: #268bd2;
            margin-top: 10px;
        }

        .buy-btn:hover {
            transition: all ease 200ms;
            box-shadow: #555 2px 5px 10px;
            background: #eee;
            color: dodgerblue !important;
        }

        .maoyun{
            padding-top: 5px;
        }


    </style>
</head>
<body>
<!--<div id="ad" style="display: none">-->
<!--<div class="ad ad0"-->
<!--onclick="_track('aliyun','https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=8hhi4dts')">-->
<!--<div style="font-size: 1.3em; padding-right: 120px; position: relative; top: 12px">阿里云新春特惠</div>-->
<!--<div style="color:orange; font-size: 13px">限时红包 最高￥<span style="font-size: 40px">1888</span></div>-->
<!--</div>-->
<!--<div class="ad ad1"-->
<!--onclick="_track('aliyun-puhui','https://promotion.aliyun.com/ntms/act/qwbk.html?spm=5176.11533457.1089570.10.74e877e33jtaGy&userCode=8hhi4dts')">-->
<!--<div style="font-size: 1.5em;">阿里云全民云计算-新春特惠</div>-->
<!--<div style="color:orange; font-size: 18px;padding-top: 4px;">普惠上云，云服务器1核1G仅需293元/年</div>-->
<!--</div>-->
<!--</div>-->

<div class="ad"  style="text-align:center; padding-bottom:30px; display: none"><a href="https://item.jd.com/12816296.html" onclick="buy('img')" title='点击购买' target="_blank"><img style="height:250px;box-shadow: #aaa 5px 5px 10px;" src="https://pcdn.flutterchina.club/imgs/book.png"/></a>  <br/> <a class="buy-btn" onclick="buy('btn')" href="https://item.jd.com/12816296.html" title='点击购买' target="_blank"> 购买实体书 </a></div>


<!--<div class="ad"  style="text-align:center; padding-bottom:30px; display: none"><a href="https://item.jd.com/12816296.html" onclick="buy('img')" title='点击购买' target="_blank"><img style="height:250px;box-shadow: #aaa 5px 5px 10px;" src="https://pcdn.flutterchina.club/imgs/book.png"/></a>  <br/> <a class="buy-btn" onclick="buy('img')" href="https://item.jd.com/12816296.html" title='点击购买' target="_blank"> 购买实体书 </a>-->
    <!--<a id="jd" href="https://item.jd.com/12816296.html" onclick="buy('jd')"  style=" display: block; padding: 10px; color: red; text-decoration: underline; ">即日起至4.23日，京东图书每满100减50！ </a>-->
<!--</div>-->


<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    
    
        
        <li>
            <a href="https://flutterchina.club" target="_blank" class="custom-link"><div><img height=20 style='position:relative; top:5px; padding-right:5px ' src='https://cdn.jsdelivr.net/gh/flutterchina/website@1.0/images/favicon.png'/> Flutter中文网</div></a>
        </li>
    
    

    
    <li class="divider"></li>
    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="../">
            
                <a href="../">
            
                    
                    简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../intro.html">
            
                <a href="../intro.html">
            
                    
                    前言
            
                </a>
            

            
        </li>
    

    
        
        <li class="header">入门篇</li>
        
        
    
        <li class="chapter " data-level="2.1" data-path="./">
            
                <a href="./">
            
                    
                    第一章：起步
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.1.1" data-path="mobile_development_intro.html">
            
                <a href="mobile_development_intro.html">
            
                    
                    1.1：移动开发技术简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.2" data-path="flutter_intro.html">
            
                <a href="flutter_intro.html">
            
                    
                    1.2：初识Flutter
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="2.1.3" data-path="install_flutter.html">
            
                <a href="install_flutter.html">
            
                    
                    1.3：搭建Flutter开发环境
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.4" data-path="dart.html">
            
                <a href="dart.html">
            
                    
                    1.4：Dart语言简介
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.2" data-path="../chapter2/">
            
                <a href="../chapter2/">
            
                    
                    第二章：第一个Flutter应用
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.2.1" data-path="../chapter2/first_flutter_app.html">
            
                <a href="../chapter2/first_flutter_app.html">
            
                    
                    2.1：计数器示例
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.2.2" data-path="../chapter2/flutter_router.html">
            
                <a href="../chapter2/flutter_router.html">
            
                    
                    2.2：路由管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.2.3" data-path="../chapter2/flutter_package_mgr.html">
            
                <a href="../chapter2/flutter_package_mgr.html">
            
                    
                    2.3：包管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.2.4" data-path="../chapter2/flutter_assets_mgr.html">
            
                <a href="../chapter2/flutter_assets_mgr.html">
            
                    
                    2.4：资源管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.2.5" data-path="../chapter2/flutter_app_debug.html">
            
                <a href="../chapter2/flutter_app_debug.html">
            
                    
                    2.5：调试Flutter APP
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.2.6" data-path="../chapter2/thread_model_and_error_report.html">
            
                <a href="../chapter2/thread_model_and_error_report.html">
            
                    
                    2.6：Dart线程模型及异常捕获
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.3" data-path="../chapter3/">
            
                <a href="../chapter3/">
            
                    
                    第三章：基础组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.3.1" data-path="../chapter3/flutter_widget_intro.html">
            
                <a href="../chapter3/flutter_widget_intro.html">
            
                    
                    3.1：Widget简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.2" data-path="../chapter3/state_manage.html">
            
                <a href="../chapter3/state_manage.html">
            
                    
                    3.2：状态管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.3" data-path="../chapter3/text.html">
            
                <a href="../chapter3/text.html">
            
                    
                    3.3：文本、字体样式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.4" data-path="../chapter3/buttons.html">
            
                <a href="../chapter3/buttons.html">
            
                    
                    3.4：按钮
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.5" data-path="../chapter3/img_and_icon.html">
            
                <a href="../chapter3/img_and_icon.html">
            
                    
                    3.5：图片和Icon
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.6" data-path="../chapter3/radio_and_checkbox.html">
            
                <a href="../chapter3/radio_and_checkbox.html">
            
                    
                    3.6：单选框和复选框
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.7" data-path="../chapter3/input_and_form.html">
            
                <a href="../chapter3/input_and_form.html">
            
                    
                    3.7：输入框和表单
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.3.8" data-path="../chapter3/progress.html">
            
                <a href="../chapter3/progress.html">
            
                    
                    3.8：进度指示器
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.4" data-path="../chapter4/">
            
                <a href="../chapter4/">
            
                    
                    第四章：布局类组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.4.1" data-path="../chapter4/intro.html">
            
                <a href="../chapter4/intro.html">
            
                    
                    4.1：布局类组件简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.4.2" data-path="../chapter4/row_and_column.html">
            
                <a href="../chapter4/row_and_column.html">
            
                    
                    4.2：线性布局（Row、Column）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.4.3" data-path="../chapter4/flex.html">
            
                <a href="../chapter4/flex.html">
            
                    
                    4.3：弹性布局（Flex）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.4.4" data-path="../chapter4/wrap_and_flow.html">
            
                <a href="../chapter4/wrap_and_flow.html">
            
                    
                    4.4：流式布局（Wrap、Flow）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.4.5" data-path="../chapter4/stack.html">
            
                <a href="../chapter4/stack.html">
            
                    
                    4.5：层叠布局（Stack、Positioned）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.4.6" data-path="../chapter4/alignment.html">
            
                <a href="../chapter4/alignment.html">
            
                    
                    4.6：对齐与相对定位（Align）
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.5" data-path="../chapter5/">
            
                <a href="../chapter5/">
            
                    
                    第五章：容器类组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.5.1" data-path="../chapter5/padding.html">
            
                <a href="../chapter5/padding.html">
            
                    
                    5.1：填充（Padding）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.2" data-path="../chapter5/constrainedbox_and_sizebox.html">
            
                <a href="../chapter5/constrainedbox_and_sizebox.html">
            
                    
                    5.2：尺寸限制类容器（ConstrainedBox等）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.3" data-path="../chapter5/decoratedbox.html">
            
                <a href="../chapter5/decoratedbox.html">
            
                    
                    5.3：装饰容器（DecoratedBox）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.4" data-path="../chapter5/transform.html">
            
                <a href="../chapter5/transform.html">
            
                    
                    5.4：变换（Transform）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.5" data-path="../chapter5/container.html">
            
                <a href="../chapter5/container.html">
            
                    
                    5.5：Container容器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.6" data-path="../chapter5/material_scaffold.html">
            
                <a href="../chapter5/material_scaffold.html">
            
                    
                    5.6：Scaffold、TabBar、底部导航
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.5.7" data-path="../chapter5/clip.html">
            
                <a href="../chapter5/clip.html">
            
                    
                    5.7：剪裁（Clip）
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.6" data-path="../chapter6/">
            
                <a href="../chapter6/">
            
                    
                    第六章：可滚动组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.6.1" data-path="../chapter6/intro.html">
            
                <a href="../chapter6/intro.html">
            
                    
                    6.1：可滚动组件简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.6.2" data-path="../chapter6/single_child_scrollview.html">
            
                <a href="../chapter6/single_child_scrollview.html">
            
                    
                    6.2：SingleChildScrollView
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.6.3" data-path="../chapter6/listview.html">
            
                <a href="../chapter6/listview.html">
            
                    
                    6.3：ListView
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.6.4" data-path="../chapter6/gridview.html">
            
                <a href="../chapter6/gridview.html">
            
                    
                    6.4：GridView
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.6.5" data-path="../chapter6/custom_scrollview.html">
            
                <a href="../chapter6/custom_scrollview.html">
            
                    
                    6.5：CustomScrollView
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.6.6" data-path="../chapter6/scroll_controller.html">
            
                <a href="../chapter6/scroll_controller.html">
            
                    
                    6.6：滚动监听及控制（ScrollController）
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2.7" data-path="../chapter7/">
            
                <a href="../chapter7/">
            
                    
                    第七章：功能型组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.7.1" data-path="../chapter7/willpopscope.html">
            
                <a href="../chapter7/willpopscope.html">
            
                    
                    7.1：导航返回拦截（WillPopScope）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.7.2" data-path="../chapter7/inherited_widget.html">
            
                <a href="../chapter7/inherited_widget.html">
            
                    
                    7.2：数据共享（InheritedWidget）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.7.3" data-path="../chapter7/provider.html">
            
                <a href="../chapter7/provider.html">
            
                    
                    7.3： 跨组件状态共享（Provider）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.7.4" data-path="../chapter7/theme.html">
            
                <a href="../chapter7/theme.html">
            
                    
                    7.4：颜色和主题（Theme）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.7.5" data-path="../chapter7/futurebuilder_and_streambuilder.html">
            
                <a href="../chapter7/futurebuilder_and_streambuilder.html">
            
                    
                    7.5：异步UI更新（FutureBuilder、StreamBuilder）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.7.6" data-path="../chapter7/dailog.html">
            
                <a href="../chapter7/dailog.html">
            
                    
                    7.6：对话框详解
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">进阶篇</li>
        
        
    
        <li class="chapter " data-level="3.1" data-path="../chapter8/">
            
                <a href="../chapter8/">
            
                    
                    第八章：事件处理与通知
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.1" data-path="../chapter8/listener.html">
            
                <a href="../chapter8/listener.html">
            
                    
                    8.1：原始指针事件处理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2" data-path="../chapter8/gesture.html">
            
                <a href="../chapter8/gesture.html">
            
                    
                    8.2：手势识别
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3" data-path="../chapter8/eventbus.html">
            
                <a href="../chapter8/eventbus.html">
            
                    
                    8.3：全局事件总线
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4" data-path="../chapter8/notification.html">
            
                <a href="../chapter8/notification.html">
            
                    
                    8.4：通知(Notification)
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.2" data-path="../chapter9/">
            
                <a href="../chapter9/">
            
                    
                    第九章：动画
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.2.1" data-path="../chapter9/intro.html">
            
                <a href="../chapter9/intro.html">
            
                    
                    9.1：Flutter动画简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.2" data-path="../chapter9/animation_structure.html">
            
                <a href="../chapter9/animation_structure.html">
            
                    
                    9.2：动画结构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.3" data-path="../chapter9/route_transition.html">
            
                <a href="../chapter9/route_transition.html">
            
                    
                    9.3：自定义路由过渡动画
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.4" data-path="../chapter9/hero.html">
            
                <a href="../chapter9/hero.html">
            
                    
                    9.4：Hero动画
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.5" data-path="../chapter9/stagger_animation.html">
            
                <a href="../chapter9/stagger_animation.html">
            
                    
                    9.5：交织动画
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.6" data-path="../chapter9/animated_switcher.html">
            
                <a href="../chapter9/animated_switcher.html">
            
                    
                    9.6：通用“动画切换”组件（AnimatedSwitcher）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.2.7" data-path="../chapter9/animated_widgets.html">
            
                <a href="../chapter9/animated_widgets.html">
            
                    
                    9.7：动画过渡组件
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.3" data-path="../chapter10/">
            
                <a href="../chapter10/">
            
                    
                    第十章：自定义组件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.3.1" data-path="../chapter10/intro.html">
            
                <a href="../chapter10/intro.html">
            
                    
                    10.1：自定义组件方法简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.3.2" data-path="../chapter10/combine.html">
            
                <a href="../chapter10/combine.html">
            
                    
                    10.2：组合现有组件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.3.3" data-path="../chapter10/turn_box.html">
            
                <a href="../chapter10/turn_box.html">
            
                    
                    10.3：组合实例：TurnBox
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.3.4" data-path="../chapter10/custom_paint.html">
            
                <a href="../chapter10/custom_paint.html">
            
                    
                    10.4：自绘组件（CustomPaint与Canvas）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.3.5" data-path="../chapter10/gradient_circular_progress_demo.html">
            
                <a href="../chapter10/gradient_circular_progress_demo.html">
            
                    
                    10.5：自绘实例：圆形渐变进度条(自绘)
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.4" data-path="../chapter11/">
            
                <a href="../chapter11/">
            
                    
                    第十一章：文件操作与网络请求
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.4.1" data-path="../chapter11/file_operation.html">
            
                <a href="../chapter11/file_operation.html">
            
                    
                    11.1：文件操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.2" data-path="../chapter11/http.html">
            
                <a href="../chapter11/http.html">
            
                    
                    11.2：Http请求-HttpClient
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.3" data-path="../chapter11/dio.html">
            
                <a href="../chapter11/dio.html">
            
                    
                    11.3：Http请求-Dio package
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.4" data-path="../chapter11/download_with_chunks.html">
            
                <a href="../chapter11/download_with_chunks.html">
            
                    
                    11.4：实例：Http分块下载
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.5" data-path="../chapter11/websocket.html">
            
                <a href="../chapter11/websocket.html">
            
                    
                    11.5：WebSocket
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.6" data-path="../chapter11/socket.html">
            
                <a href="../chapter11/socket.html">
            
                    
                    11.6：使用Socket API
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.4.7" data-path="../chapter11/json_model.html">
            
                <a href="../chapter11/json_model.html">
            
                    
                    11.7：Json转Dart Model类
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.5" data-path="../chapter12/">
            
                <a href="../chapter12/">
            
                    
                    第十二章：包与插件
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.5.1" data-path="../chapter12/develop_package.html">
            
                <a href="../chapter12/develop_package.html">
            
                    
                    12.1：开发package
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.5.2" data-path="../chapter12/platform-channel.html">
            
                <a href="../chapter12/platform-channel.html">
            
                    
                    12.2：平台通道简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.5.3" data-path="../chapter12/develop_plugin.html">
            
                <a href="../chapter12/develop_plugin.html">
            
                    
                    12.3：开发Flutter插件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.5.4" data-path="../chapter12/android_implement.html">
            
                <a href="../chapter12/android_implement.html">
            
                    
                    12.4：插件开发：实现Android端API
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.5.5" data-path="../chapter12/ios_implement.html">
            
                <a href="../chapter12/ios_implement.html">
            
                    
                    12.5：插件开发：实现IOS端API
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.5.6" data-path="../chapter12/texture_platformview.html">
            
                <a href="../chapter12/texture_platformview.html">
            
                    
                    12.6：Texture和PlatformView
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.6" data-path="../chapter13/">
            
                <a href="../chapter13/">
            
                    
                    第十三章：国际化
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.6.1" data-path="../chapter13/multi_languages_support.html">
            
                <a href="../chapter13/multi_languages_support.html">
            
                    
                    13.1：让App支持多语言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.6.2" data-path="../chapter13/locallization_implement.html">
            
                <a href="../chapter13/locallization_implement.html">
            
                    
                    13.2：实现Localizations
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.6.3" data-path="../chapter13/intl.html">
            
                <a href="../chapter13/intl.html">
            
                    
                    13.3：使用Intl包
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.6.4" data-path="../chapter13/faq.html">
            
                <a href="../chapter13/faq.html">
            
                    
                    13.4：国际化常见问题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.7" data-path="../chapter14/">
            
                <a href="../chapter14/">
            
                    
                    第十四章：Flutter核心原理
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.7.1" data-path="../chapter14/flutter_ui_system.html">
            
                <a href="../chapter14/flutter_ui_system.html">
            
                    
                    14.1：Flutter UI系统
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.7.2" data-path="../chapter14/element_buildcontext.html">
            
                <a href="../chapter14/element_buildcontext.html">
            
                    
                    14.2：Element和BuildContext
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.7.3" data-path="../chapter14/render_object.html">
            
                <a href="../chapter14/render_object.html">
            
                    
                    14.3：RenderObject与RenderBox
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.7.4" data-path="../chapter14/flutter_app_startup.html">
            
                <a href="../chapter14/flutter_app_startup.html">
            
                    
                    14.4：Flutter从启动到显示
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.7.5" data-path="../chapter14/image_and_cache.html">
            
                <a href="../chapter14/image_and_cache.html">
            
                    
                    14.5：Flutter图片加载与缓存
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">实例篇</li>
        
        
    
        <li class="chapter " data-level="4.1" data-path="../chapter15/intro.html">
            
                <a href="../chapter15/intro.html">
            
                    
                    第十五章：一个完整的Flutter应用
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.1" data-path="../chapter15/intro.html">
            
                <a href="../chapter15/intro.html">
            
                    
                    15.1：应用简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2" data-path="../chapter15/code_structure.html">
            
                <a href="../chapter15/code_structure.html">
            
                    
                    15.2：APP代码结构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3" data-path="../chapter15/models.html">
            
                <a href="../chapter15/models.html">
            
                    
                    15.3：Model类定义
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4" data-path="../chapter15/globals.html">
            
                <a href="../chapter15/globals.html">
            
                    
                    15.4：全局变量及共享状态
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5" data-path="../chapter15/network.html">
            
                <a href="../chapter15/network.html">
            
                    
                    15.5：网络请求封装
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6" data-path="../chapter15/entry.html">
            
                <a href="../chapter15/entry.html">
            
                    
                    15.6：App入口及首页
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.7" data-path="../chapter15/login_page.html">
            
                <a href="../chapter15/login_page.html">
            
                    
                    15.7：登录页
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.8" data-path="../chapter15/language_and_theme_setting.html">
            
                <a href="../chapter15/language_and_theme_setting.html">
            
                    
                    15.8：多语言和多主题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="https://pcdn.flutterchina.club/gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    
    <a class="btn pull-right" aria-label="GitHub">
        <i class="fa fa-edit" title="编辑本文"></i>
    </a>
    <a class="btn pull-right" aria-label="GitHub" href="https://github.com/flutterchina/flutter-in-action">
        <i class="fa fa-github" title="查看本书开源项目"></i>
    </a>
    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href=".." >1.3：搭建Flutter开发环境</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <h1 id="13-&#x642D;&#x5EFA;flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;">1.3 &#x642D;&#x5EFA;Flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;</h1>
<p>&#x5DE5;&#x6B32;&#x5584;&#x5176;&#x4E8B;&#x5FC5;&#x5148;&#x5229;&#x5176;&#x5668;&#xFF0C;&#x672C;&#x8282;&#x9996;&#x5148;&#x4F1A;&#x5206;&#x522B;&#x4ECB;&#x7ECD;&#x4E00;&#x4E0B;&#x5728;Windows&#x548C;macOS&#x4E0B;Flutter SDK&#x7684;&#x5B89;&#x88C5;&#xFF0C;&#x7136;&#x540E;&#x518D;&#x4ECB;&#x7ECD;&#x4E00;&#x4E0B;&#x914D;IDE&#x548C;&#x6A21;&#x62DF;&#x5668;&#x7684;&#x4F7F;&#x7528;&#x3002;</p>
<h2 id="131-&#x5B89;&#x88C5;flutter">1.3.1 &#x5B89;&#x88C5;Flutter</h2>
<p>&#x7531;&#x4E8E;Flutter&#x4F1A;&#x540C;&#x65F6;&#x6784;&#x5EFA;Android&#x548C;IOS&#x4E24;&#x4E2A;&#x5E73;&#x53F0;&#x7684;&#x53D1;&#x5E03;&#x5305;&#xFF0C;&#x6240;&#x4EE5;Flutter&#x540C;&#x65F6;&#x4F9D;&#x8D56;Android SDK&#x548C;iOS SDK&#xFF0C;&#x5728;&#x5B89;&#x88C5;Flutter&#x65F6;&#x4E5F;&#x9700;&#x8981;&#x5B89;&#x88C5;&#x76F8;&#x5E94;&#x5E73;&#x53F0;&#x7684;&#x6784;&#x5EFA;&#x5DE5;&#x5177;&#x548C;SDK&#x3002;&#x4E0B;&#x9762;&#x6211;&#x4EEC;&#x5206;&#x522B;&#x4ECB;&#x7ECD;&#x4E00;&#x4E0B;Windows&#x548C;macOS&#x4E0B;&#x7684;&#x73AF;&#x5883;&#x642D;&#x5EFA;&#x3002;</p>
<blockquote>
<p>&#x6CE8;&#x610F;&#xFF1A;&#x672C;&#x8282;&#x4ECB;&#x7ECD;&#x7684;&#x5B89;&#x88C5;&#x65B9;&#x5F0F;&#x968F;&#x7740;Flutter&#x7684;&#x5347;&#x7EA7;&#x53EF;&#x80FD;&#x4F1A;&#x53D1;&#x751F;&#x53D8;&#x5316;&#xFF0C;&#x5982;&#x679C;&#x4E0B;&#x9762;&#x4ECB;&#x7ECD;&#x7684;&#x5185;&#x5BB9;&#x5728;&#x60A8;&#x5B89;&#x88C5;Flutter&#x65F6;&#x5DF2;&#x7ECF;&#x5931;&#x6548;&#xFF0C;&#x8BF7;&#x8BBF;&#x95EE;Flutter&#x5B98;&#x7F51;&#xFF0C;&#x6309;&#x7167;&#x5B98;&#x7F51;&#x6700;&#x65B0;&#x7684;&#x5B89;&#x88C5;&#x6559;&#x7A0B;&#x5B89;&#x88C5;&#x3002;</p>
</blockquote>
<h3 id="&#x4F7F;&#x7528;&#x955C;&#x50CF;">&#x4F7F;&#x7528;&#x955C;&#x50CF;</h3>
<p>&#x7531;&#x4E8E;&#x5728;&#x56FD;&#x5185;&#x8BBF;&#x95EE;Flutter&#x6709;&#x65F6;&#x53EF;&#x80FD;&#x4F1A;&#x53D7;&#x5230;&#x9650;&#x5236;&#xFF0C;Flutter&#x5B98;&#x65B9;&#x4E3A;&#x4E2D;&#x56FD;&#x5F00;&#x53D1;&#x8005;&#x642D;&#x5EFA;&#x4E86;&#x4E34;&#x65F6;&#x955C;&#x50CF;&#xFF0C;&#x5927;&#x5BB6;&#x53EF;&#x4EE5;&#x5C06;&#x5982;&#x4E0B;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x52A0;&#x5165;&#x5230;&#x7528;&#x6237;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x4E2D;&#xFF1A;</p>
<pre class="language-"><code>export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
</code></pre><p><strong>&#x6CE8;&#x610F;&#xFF1A;</strong> &#x6B64;&#x955C;&#x50CF;&#x4E3A;&#x4E34;&#x65F6;&#x955C;&#x50CF;&#xFF0C;&#x5E76;&#x4E0D;&#x80FD;&#x4FDD;&#x8BC1;&#x4E00;&#x76F4;&#x53EF;&#x7528;&#xFF0C;&#x8BFB;&#x8005;&#x53EF;&#x4EE5;&#x53C2;&#x8003;<a href="https://flutter.io/community/china" target="_blank">https://flutter.io/community/china</a> &#x4EE5;&#x83B7;&#x5F97;&#x6709;&#x5173;&#x955C;&#x50CF;&#x670D;&#x52A1;&#x5668;&#x7684;&#x6700;&#x65B0;&#x52A8;&#x6001;&#x3002;</p>
<h3 id="&#x5728;windows&#x4E0A;&#x642D;&#x5EFA;flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;">&#x5728;Windows&#x4E0A;&#x642D;&#x5EFA;Flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;</h3>
<h4 id="&#x7CFB;&#x7EDF;&#x8981;&#x6C42;">&#x7CFB;&#x7EDF;&#x8981;&#x6C42;</h4>
<p>&#x8981;&#x5B89;&#x88C5;&#x5E76;&#x8FD0;&#x884C;Flutter&#xFF0C;&#x60A8;&#x7684;&#x5F00;&#x53D1;&#x73AF;&#x5883;&#x5FC5;&#x987B;&#x6EE1;&#x8DB3;&#x4EE5;&#x4E0B;&#x6700;&#x4F4E;&#x8981;&#x6C42;:</p>
<ul>
<li><p>&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;: Windows 7 &#x6216;&#x66F4;&#x9AD8;&#x7248;&#x672C; (64-bit)</p>
</li>
<li><p>&#x78C1;&#x76D8;&#x7A7A;&#x95F4;: 400 MB (&#x4E0D;&#x5305;&#x62EC;Android Studio&#x7684;&#x78C1;&#x76D8;&#x7A7A;&#x95F4;).</p>
</li>
<li><p>&#x5DE5;&#x5177;: Flutter &#x4F9D;&#x8D56;&#x4E0B;&#x9762;&#x8FD9;&#x4E9B;&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;.</p>
<ul>
<li><p><a href="https://docs.microsoft.com/en-us/powershell/scripting/setup/installing-windows-powershell#upgrading-existing-windows-powershell" target="_blank">PowerShell 5.0</a> &#x6216;&#x66F4;&#x65B0;&#x7684;&#x7248;&#x672C;</p>
</li>
<li><p><a href="https://git-scm.com/download/win" target="_blank">Git for Windows</a>  (Git&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;)&#xFF1B;</p>
</li>
</ul>
<p>&#x5982;&#x679C;&#x5DF2;&#x5B89;&#x88C5;Git for Windows&#xFF0C;&#x8BF7;&#x786E;&#x4FDD;&#x53EF;&#x4EE5;&#x5728;&#x547D;&#x4EE4;&#x63D0;&#x793A;&#x7B26;&#x6216;PowerShell&#x4E2D;&#x8FD0;&#x884C; git &#x547D;&#x4EE4;</p>
</li>
</ul>
<h4 id="&#x83B7;&#x53D6;flutter-sdk">&#x83B7;&#x53D6;Flutter SDK</h4>
<ol>
<li><p>&#x53BB;flutter&#x5B98;&#x7F51;&#x4E0B;&#x8F7D;&#x5176;&#x6700;&#x65B0;&#x53EF;&#x7528;&#x7684;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x4E0B;&#x8F7D;&#x5730;&#x5740;&#xFF1A;<a href="https://flutter.dev/docs/development/tools/sdk/releases" target="_blank">https://flutter.dev/docs/development/tools/sdk/releases</a> &#xFF0C;&#x6253;&#x5F00;&#x540E;&#x5982;&#x56FE;1-2&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-2.png" alt="&#x56FE;1-2"></p>
</li>
</ol>
<p>   &#x6CE8;&#x610F;&#xFF0C;Flutter&#x7684;&#x6E20;&#x9053;&#x7248;&#x672C;&#x4F1A;&#x4E0D;&#x505C;&#x53D8;&#x52A8;&#xFF0C;&#x8BF7;&#x4EE5;Flutter&#x5B98;&#x7F51;&#x4E3A;&#x51C6;&#x3002;&#x53E6;&#x5916;&#xFF0C;&#x5728;&#x4E2D;&#x56FD;&#x5927;&#x9646;&#x5730;&#x533A;&#xFF0C;&#x8981;&#x60F3;&#x6B63;&#x5E38;&#x83B7;&#x53D6;&#x5B89;&#x88C5;&#x5305;&#x5217;&#x8868;&#x6216;&#x4E0B;&#x8F7D;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x7FFB;&#x5899;&#xFF0C;&#x8BFB;&#x8005;&#x4E5F;&#x53EF;&#x4EE5;&#x53BB;Flutter github&#x9879;&#x76EE;&#x4E0B;&#x53BB;&#x4E0B;&#x8F7D;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x5730;&#x5740;&#xFF1A;<a href="https://github.com/flutter/flutter/releases" target="_blank">https://github.com/flutter/flutter/releases</a> &#x3002;</p>
<ol>
<li><p>&#x5C06;&#x5B89;&#x88C5;&#x5305;zip&#x89E3;&#x538B;&#x5230;&#x4F60;&#x60F3;&#x5B89;&#x88C5;Flutter SDK&#x7684;&#x8DEF;&#x5F84;&#xFF08;&#x5982;&#xFF1A;<code>C:\src\flutter</code>&#xFF1B;&#x6CE8;&#x610F;&#xFF0C;<strong>&#x4E0D;&#x8981;</strong>&#x5C06;flutter&#x5B89;&#x88C5;&#x5230;&#x9700;&#x8981;&#x4E00;&#x4E9B;&#x9AD8;&#x6743;&#x9650;&#x7684;&#x8DEF;&#x5F84;&#x5982;<code>C:\Program Files\</code>&#xFF09;&#x3002;</p>
</li>
<li><p>&#x5728;Flutter&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x7684;<code>flutter</code>&#x6587;&#x4EF6;&#x4E0B;&#x627E;&#x5230;<code>flutter_console.bat</code>&#xFF0C;&#x53CC;&#x51FB;&#x8FD0;&#x884C;&#x5E76;&#x542F;&#x52A8;<strong>flutter&#x547D;&#x4EE4;&#x884C;</strong>&#xFF0C;&#x63A5;&#x4E0B;&#x6765;&#xFF0C;&#x4F60;&#x5C31;&#x53EF;&#x4EE5;&#x5728;Flutter&#x547D;&#x4EE4;&#x884C;&#x8FD0;&#x884C;flutter&#x547D;&#x4EE4;&#x4E86;&#x3002;</p>
</li>
</ol>
<h5 id="&#x66F4;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;">&#x66F4;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;</h5>
<p>&#x5982;&#x679C;&#x4F60;&#x60F3;&#x5728;Windows&#x7CFB;&#x7EDF;&#x81EA;&#x5E26;&#x547D;&#x4EE4;&#x884C;&#x8FD0;&#x884C;flutter&#x547D;&#x4EE4;&#xFF0C;&#x9700;&#x8981;&#x6DFB;&#x52A0;&#x4EE5;&#x4E0B;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x5230;&#x7528;&#x6237;PATH&#xFF1A;</p>
<ul>
<li>&#x8F6C;&#x5230; &#x201C;&#x63A7;&#x5236;&#x9762;&#x677F;&gt;&#x7528;&#x6237;&#x5E10;&#x6237;&gt;&#x7528;&#x6237;&#x5E10;&#x6237;&gt;&#x66F4;&#x6539;&#x6211;&#x7684;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x201D;</li>
<li>&#x5728;&#x201C;&#x7528;&#x6237;&#x53D8;&#x91CF;&#x201D;&#x4E0B;&#x68C0;&#x67E5;&#x662F;&#x5426;&#x6709;&#x540D;&#x4E3A;&#x201C;Path&#x201D;&#x7684;&#x6761;&#x76EE;:<ul>
<li>&#x5982;&#x679C;&#x8BE5;&#x6761;&#x76EE;&#x5B58;&#x5728;&#xFF0C; &#x8FFD;&#x52A0; flutter\bin&#x7684;&#x5168;&#x8DEF;&#x5F84;&#xFF0C;&#x4F7F;&#x7528; ; &#x4F5C;&#x4E3A;&#x5206;&#x9694;&#x7B26;.</li>
<li>&#x5982;&#x679C;&#x8BE5;&#x6761;&#x76EE;&#x4E0D;&#x5B58;&#x5728;&#xFF0C;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x65B0;&#x7528;&#x6237;&#x53D8;&#x91CF; Path &#xFF0C;&#x7136;&#x540E;&#x5C06; <code>flutter\bin</code> &#x7684;&#x5168;&#x8DEF;&#x5F84;&#x4F5C;&#x4E3A;&#x5B83;&#x7684;&#x503C;.</li>
</ul>
</li>
</ul>
<p>&#x91CD;&#x542F;Windows&#x4EE5;&#x5E94;&#x7528;&#x6B64;&#x66F4;&#x6539;.</p>
<h5 id="&#x8FD0;&#x884C;-flutter-doctor&#x547D;&#x4EE4;">&#x8FD0;&#x884C; flutter doctor&#x547D;&#x4EE4;</h5>
<p>&#x5728;Flutter&#x547D;&#x4EE4;&#x884C;&#x8FD0;&#x884C;&#x5982;&#x4E0B;&#x547D;&#x4EE4;&#x6765;&#x67E5;&#x770B;&#x662F;&#x5426;&#x8FD8;&#x9700;&#x8981;&#x5B89;&#x88C5;&#x5176;&#x5B83;&#x4F9D;&#x8D56;&#xFF0C;&#x5982;&#x679C;&#x9700;&#x8981;&#xFF0C;&#x5B89;&#x88C5;&#x5B83;&#x4EEC;&#xFF1A;</p>
<pre class="language-"><code class="lang-shell">flutter doctor
</code></pre>
<p>&#x8BE5;&#x547D;&#x4EE4;&#x68C0;&#x67E5;&#x4F60;&#x7684;&#x73AF;&#x5883;&#x5E76;&#x5728;&#x547D;&#x4EE4;&#x884C;&#x7A97;&#x53E3;&#x4E2D;&#x663E;&#x793A;&#x62A5;&#x544A;&#x3002;Dart SDK&#x5DF2;&#x7ECF;&#x5728;&#x6253;&#x5305;&#x5728;Flutter SDK&#x91CC;&#x4E86;&#xFF0C;&#x6CA1;&#x6709;&#x5FC5;&#x8981;&#x5355;&#x72EC;&#x5B89;&#x88C5;Dart&#x3002; &#x4ED4;&#x7EC6;&#x68C0;&#x67E5;&#x547D;&#x4EE4;&#x884C;&#x8F93;&#x51FA;&#x4EE5;&#x83B7;&#x53D6;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x5B89;&#x88C5;&#x7684;&#x5176;&#x4ED6;&#x8F6F;&#x4EF6;&#x6216;&#x8FDB;&#x4E00;&#x6B65;&#x9700;&#x8981;&#x6267;&#x884C;&#x7684;&#x4EFB;&#x52A1;&#x3002;</p>
<p>&#x4F8B;&#x5982;&#xFF1A;</p>
<pre class="language-"><code>[-] Android toolchain - develop for Android devices
    &#x2022; Android SDK at D:\Android\sdk
    &#x2717; Android SDK is missing command line tools; download from https://goo.gl/XxQghQ
    &#x2022; Try re-installing or updating your Android SDK,
      visit https://flutter.io/setup/#android-setup for detailed instructions.
</code></pre><p>&#x7B2C;&#x4E00;&#x6B21;&#x8FD0;&#x884C;flutter&#x547D;&#x4EE4;&#xFF08;&#x5982;<code>flutter doctor</code>&#xFF09;&#x65F6;&#xFF0C;&#x5B83;&#x4F1A;&#x4E0B;&#x8F7D;&#x5B83;&#x81EA;&#x5DF1;&#x7684;&#x4F9D;&#x8D56;&#x9879;&#x5E76;&#x81EA;&#x884C;&#x7F16;&#x8BD1;&#x3002;&#x4EE5;&#x540E;&#x518D;&#x8FD0;&#x884C;&#x5C31;&#x4F1A;&#x5FEB;&#x5F97;&#x591A;&#x3002;&#x7F3A;&#x5931;&#x7684;&#x4F9D;&#x8D56;&#x9700;&#x8981;&#x5B89;&#x88C5;&#x4E00;&#x4E0B;&#xFF0C;&#x5B89;&#x88C5;&#x5B8C;&#x6210;&#x540E;&#x518D;&#x8FD0;&#x884C;<code>flutter doctor</code>&#x547D;&#x4EE4;&#x6765;&#x9A8C;&#x8BC1;&#x662F;&#x5426;&#x5B89;&#x88C5;&#x6210;&#x529F;&#x3002;</p>
<h4 id="android&#x8BBE;&#x7F6E;">Android&#x8BBE;&#x7F6E;</h4>
<p>Flutter&#x4F9D;&#x8D56;&#x4E8E;Android Studio&#x7684;&#x5168;&#x91CF;&#x5B89;&#x88C5;&#x3002;Android Studio&#x4E0D;&#x4EC5;&#x53EF;&#x4EE5;&#x7BA1;&#x7406;Android &#x5E73;&#x53F0;&#x4F9D;&#x8D56;&#x3001;SDK&#x7248;&#x672C;&#x7B49;&#xFF0C;&#x800C;&#x4E14;&#x5B83;&#x4E5F;&#x662F;Flutter&#x5F00;&#x53D1;&#x63A8;&#x8350;&#x7684;IDE&#x4E4B;&#x4E00;&#xFF08;&#x5F53;&#x7136;&#xFF0C;&#x4F60;&#x4E5F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x5176;&#x5B83;&#x7F16;&#x8F91;&#x5668;&#x6216;IDE&#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x4F1A;&#x5728;&#x540E;&#x9762;&#x8BA8;&#x8BBA;&#xFF09;&#x3002;</p>
<h5 id="&#x5B89;&#x88C5;android-studio">&#x5B89;&#x88C5;Android Studio</h5>
<ol>
<li>&#x4E0B;&#x8F7D;&#x5E76;&#x5B89;&#x88C5; Android Studio&#xFF0C;&#x4E0B;&#x8F7D;&#x5730;&#x5740;&#xFF1A;<a href="https://developer.android.com/studio/index.html" target="_blank">https://developer.android.com/studio/index.html</a> &#x3002;</li>
<li>&#x542F;&#x52A8;Android Studio&#xFF0C;&#x7136;&#x540E;&#x6267;&#x884C;&#x201C;Android Studio&#x5B89;&#x88C5;&#x5411;&#x5BFC;&#x201D;&#x3002;&#x8FD9;&#x5C06;&#x5B89;&#x88C5;&#x6700;&#x65B0;&#x7684;Android SDK&#x3001;Android SDK&#x5E73;&#x53F0;&#x5DE5;&#x5177;&#x548C;Android SDK&#x6784;&#x5EFA;&#x5DE5;&#x5177;&#xFF0C;&#x8FD9;&#x4E9B;&#x662F;&#x7528;Flutter&#x8FDB;&#x884C;Android&#x5F00;&#x53D1;&#x6240;&#x9700;&#x8981;&#x7684;&#x3002;</li>
</ol>
<h4 id="&#x5B89;&#x88C5;&#x9047;&#x5230;&#x95EE;&#x9898;&#xFF1F;">&#x5B89;&#x88C5;&#x9047;&#x5230;&#x95EE;&#x9898;&#xFF1F;</h4>
<p>&#x5982;&#x679C;&#x5728;&#x5B89;&#x88C5;&#x8FC7;&#x7A0B;&#x4E2D;&#x9047;&#x5230;&#x95EE;&#x9898;&#xFF0C;&#x53EF;&#x4EE5;&#x5148;&#x53BB;flutter&#x5B98;&#x7F51;&#x67E5;&#x770B;&#x4E00;&#x4E0B;&#x5B89;&#x88C5;&#x65B9;&#x5F0F;&#x662F;&#x5426;&#x53D1;&#x751F;&#x53D8;&#x5316;&#xFF0C;&#x6216;&#x8005;&#x5728;&#x7F51;&#x4E0A;&#x641C;&#x7D22;&#x4E00;&#x4E0B;&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x3002;</p>
<h3 id="&#x5728;macos&#x4E0A;&#x642D;&#x5EFA;flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;">&#x5728;macOS&#x4E0A;&#x642D;&#x5EFA;Flutter&#x5F00;&#x53D1;&#x73AF;&#x5883;</h3>
<p>&#x5728;masOS&#x4E0B;&#x53EF;&#x4EE5;&#x540C;&#x65F6;&#x8FDB;&#x884C;Android&#x548C;iOS&#x8BBE;&#x5907;&#x7684;&#x6D4B;&#x8BD5;&#x3002;</p>
<h4 id="&#x7CFB;&#x7EDF;&#x8981;&#x6C42;">&#x7CFB;&#x7EDF;&#x8981;&#x6C42;</h4>
<p>&#x8981;&#x5B89;&#x88C5;&#x5E76;&#x8FD0;&#x884C;Flutter&#xFF0C;&#x60A8;&#x7684;&#x5F00;&#x53D1;&#x73AF;&#x5883;&#x5FC5;&#x987B;&#x6EE1;&#x8DB3;&#x4EE5;&#x4E0B;&#x6700;&#x4F4E;&#x8981;&#x6C42;:</p>
<ul>
<li>&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;: macOS (64-bit)</li>
<li>&#x78C1;&#x76D8;&#x7A7A;&#x95F4;: 700 MB (&#x4E0D;&#x5305;&#x62EC;Xcode&#x6216;Android Studio&#x7684;&#x78C1;&#x76D8;&#x7A7A;&#x95F4;&#xFF09;.</li>
<li>&#x5DE5;&#x5177;: Flutter &#x4F9D;&#x8D56;&#x4E0B;&#x9762;&#x8FD9;&#x4E9B;&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;.<ul>
<li><code>bash&#x3001;mkdir&#x3001;rm&#x3001;git&#x3001;curl&#x3001;unzip&#x3001;which</code></li>
</ul>
</li>
</ul>
<h4 id="&#x83B7;&#x53D6;flutter-sdk">&#x83B7;&#x53D6;Flutter SDK</h4>
<ol>
<li><p>&#x53BB;flutter&#x5B98;&#x7F51;&#x4E0B;&#x8F7D;&#x5176;&#x6700;&#x65B0;&#x53EF;&#x7528;&#x7684;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x5B98;&#x7F51;&#x5730;&#x5740;&#xFF1A;<a href="https://flutter.io/sdk-archive/#macos" target="_blank">https://flutter.io/sdk-archive/#macos</a></p>
<p>&#x6CE8;&#x610F;&#xFF0C;Flutter&#x7684;&#x6E20;&#x9053;&#x7248;&#x672C;&#x4F1A;&#x4E0D;&#x505C;&#x53D8;&#x52A8;&#xFF0C;&#x8BF7;&#x4EE5;Flutter&#x5B98;&#x7F51;&#x4E3A;&#x51C6;&#x3002;&#x53E6;&#x5916;&#xFF0C;&#x5728;&#x4E2D;&#x56FD;&#x5927;&#x9646;&#x5730;&#x533A;&#xFF0C;&#x8981;&#x60F3;&#x6B63;&#x5E38;&#x83B7;&#x53D6;&#x5B89;&#x88C5;&#x5305;&#x5217;&#x8868;&#x6216;&#x4E0B;&#x8F7D;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x7FFB;&#x5899;&#xFF0C;&#x8BFB;&#x8005;&#x4E5F;&#x53EF;&#x4EE5;&#x53BB;Flutter github&#x9879;&#x76EE;&#x4E0B;&#x53BB;&#x4E0B;&#x8F7D;&#x5B89;&#x88C5;&#x5305;&#xFF0C;&#x5730;&#x5740;&#xFF1A;<a href="https://github.com/flutter/flutter/releases" target="_blank">https://github.com/flutter/flutter/releases</a> &#x3002;</p>
</li>
<li><p>&#x89E3;&#x538B;&#x5B89;&#x88C5;&#x5305;&#x5230;&#x4F60;&#x60F3;&#x5B89;&#x88C5;&#x7684;&#x76EE;&#x5F55;&#xFF0C;&#x5982;&#xFF1A;</p>
<pre class="language-"><code class="lang-shell"><span class="token builtin class-name">cd</span> ~/development
<span class="token function">unzip</span> ~/Downloads/flutter_macos_v0.5.1-beta.zip
</code></pre>
</li>
<li><p>&#x6DFB;&#x52A0;<code>flutter</code>&#x76F8;&#x5173;&#x5DE5;&#x5177;&#x5230;path&#x4E2D;&#xFF1A;</p>
<pre class="language-"><code class="lang-shell"><span class="token builtin class-name">export</span> <span class="token assign-left variable"><span class="token environment constant">PATH</span></span><span class="token operator">=</span><span class="token variable"><span class="token variable">`</span><span class="token builtin class-name">pwd</span><span class="token variable">`</span></span>/flutter/bin:<span class="token environment constant">$PATH</span>
</code></pre>
<p>&#x6B64;&#x4EE3;&#x7801;&#x53EA;&#x80FD;&#x6682;&#x65F6;&#x9488;&#x5BF9;&#x5F53;&#x524D;&#x547D;&#x4EE4;&#x884C;&#x7A97;&#x53E3;&#x8BBE;&#x7F6E;PATH&#x73AF;&#x5883;&#x53D8;&#x91CF;&#xFF0C;&#x8981;&#x60F3;&#x6C38;&#x4E45;&#x5C06;Flutter&#x6DFB;&#x52A0;&#x5230;PATH&#x4E2D;&#x8BF7;&#x53C2;&#x8003;&#x4E0B;&#x9762;<strong>&#x66F4;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;</strong> &#x90E8;&#x5206;&#x3002;</p>
</li>
</ol>
<h5 id="&#x8FD0;&#x884C;-flutter-doctor&#x547D;&#x4EE4;">&#x8FD0;&#x884C; flutter doctor&#x547D;&#x4EE4;</h5>
<p>&#x8FD9;&#x4E00;&#x6B65;&#x548C;Windows&#x4E0B;&#x6B65;&#x9AA4;&#x4E00;&#x81F4;&#xFF0C;&#x4E0D;&#x518D;&#x8D58;&#x8FF0;&#x3002;</p>
<h5 id="&#x66F4;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;">&#x66F4;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;</h5>
<p>&#x5C06;Flutter&#x6DFB;&#x52A0;&#x5230;PATH&#x4E2D;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x4EFB;&#x4F55;&#x7EC8;&#x7AEF;&#x4F1A;&#x8BDD;&#x4E2D;&#x8FD0;&#x884C;<code>flutter</code>&#x547D;&#x4EE4;&#x3002;</p>
<p>&#x5BF9;&#x4E8E;&#x6240;&#x6709;&#x7EC8;&#x7AEF;&#x4F1A;&#x8BDD;&#x6C38;&#x4E45;&#x4FEE;&#x6539;&#x6B64;&#x53D8;&#x91CF;&#x7684;&#x6B65;&#x9AA4;&#x662F;&#x548C;&#x7279;&#x5B9A;&#x8BA1;&#x7B97;&#x673A;&#x7CFB;&#x7EDF;&#x76F8;&#x5173;&#x7684;&#x3002;&#x901A;&#x5E38;&#xFF0C;&#x60A8;&#x4F1A;&#x5728;&#x6253;&#x5F00;&#x65B0;&#x7A97;&#x53E3;&#x65F6;&#x5C06;&#x8BBE;&#x7F6E;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x7684;&#x547D;&#x4EE4;&#x6DFB;&#x52A0;&#x5230;&#x6267;&#x884C;&#x7684;&#x6587;&#x4EF6;&#x4E2D;&#x3002;&#x4F8B;&#x5982;</p>
<ol>
<li><p>&#x786E;&#x5B9A;&#x60A8;Flutter SDK&#x7684;&#x76EE;&#x5F55;&#x8BB0;&#x4E3A;&#x201C;FLUTTER_INSTALL_PATH&#x201D;&#xFF0C;&#x60A8;&#x5C06;&#x5728;&#x6B65;&#x9AA4;3&#x4E2D;&#x7528;&#x5230;&#x3002;</p>
</li>
<li><p>&#x6253;&#x5F00;(&#x6216;&#x521B;&#x5EFA;) <code>$HOME/.bash_profile</code>&#x3002;&#x6587;&#x4EF6;&#x8DEF;&#x5F84;&#x548C;&#x6587;&#x4EF6;&#x540D;&#x53EF;&#x80FD;&#x5728;&#x4F60;&#x7684;&#x7535;&#x8111;&#x4E0A;&#x4E0D;&#x540C;.</p>
</li>
<li><p>&#x6DFB;&#x52A0;&#x4EE5;&#x4E0B;&#x8DEF;&#x5F84;:</p>
<pre class="language-"><code class="lang-shell"><span class="token builtin class-name">export</span> <span class="token assign-left variable"><span class="token environment constant">PATH</span></span><span class="token operator">=</span><span class="token punctuation">[</span>FLUTTER_INSTALL_PATH<span class="token punctuation">]</span>/flutter/bin:<span class="token environment constant">$PATH</span>
</code></pre>
<p>&#x4F8B;&#x5982;&#x7B14;&#x8005;Flutter &#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x662F;&#x201C;~/code/flutter_dir&#x201D;&#xFF0C;&#x90A3;&#x4E48;&#x4EE3;&#x7801;&#x4E3A;&#xFF1A;</p>
<pre class="language-"><code>export PATH=~/code/flutter_dir/flutter/bin:$PATH
</code></pre></li>
<li><p>&#x8FD0;&#x884C; <code>source $HOME/.bash_profile</code> &#x5237;&#x65B0;&#x5F53;&#x524D;&#x7EC8;&#x7AEF;&#x7A97;&#x53E3;&#x3002;</p>
<blockquote>
<p><strong>&#x6CE8;&#x610F;:</strong> &#x5982;&#x679C;&#x4F60;&#x4F7F;&#x7528;&#x7EC8;&#x7AEF;&#x662F;zsh&#xFF0C;&#x7EC8;&#x7AEF;&#x542F;&#x52A8;&#x65F6; <code>~/.bash_profile</code> &#x5C06;&#x4E0D;&#x4F1A;&#x88AB;&#x52A0;&#x8F7D;&#xFF0C;&#x89E3;&#x51B3;&#x529E;&#x6CD5;&#x5C31;&#x662F;&#x4FEE;&#x6539; <code>&#xFF5E;/.zshrc</code> &#xFF0C;&#x5728;&#x5176;&#x4E2D;&#x6DFB;&#x52A0;&#xFF1A;source &#xFF5E;/.bash_profile</p>
</blockquote>
</li>
<li><p>&#x9A8C;&#x8BC1;&#x201C;flutter/bin&#x201D;&#x662F;&#x5426;&#x5DF2;&#x5728;PATH&#x4E2D;&#xFF1A;</p>
<pre class="language-"><code>echo $PATH
</code></pre></li>
</ol>
<h4 id="&#x5B89;&#x88C5;-xcode">&#x5B89;&#x88C5; Xcode</h4>
<p>&#x8981;&#x4E3A;iOS&#x5F00;&#x53D1;Flutter&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#xFF0C;&#x60A8;&#x9700;&#x8981;Xcode 9.0&#x6216;&#x66F4;&#x9AD8;&#x7248;&#x672C;:</p>
<ol>
<li>&#x5B89;&#x88C5;Xcode 9.0&#x6216;&#x66F4;&#x65B0;&#x7248;&#x672C;(&#x901A;&#x8FC7;<a href="https://developer.apple.com/xcode/" target="_blank">&#x94FE;&#x63A5;&#x4E0B;&#x8F7D;</a>&#x6216;<a href="https://itunes.apple.com/us/app/xcode/id497799835" target="_blank">&#x82F9;&#x679C;&#x5E94;&#x7528;&#x5546;&#x5E97;</a>).</li>
<li>&#x914D;&#x7F6E;Xcode&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;&#x4EE5;&#x4F7F;&#x7528;&#x65B0;&#x5B89;&#x88C5;&#x7684;Xcode&#x7248;&#x672C; <code>sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer</code> &#x5BF9;&#x4E8E;&#x5927;&#x591A;&#x6570;&#x60C5;&#x51B5;&#xFF0C;&#x5F53;&#x60A8;&#x60F3;&#x8981;&#x4F7F;&#x7528;&#x6700;&#x65B0;&#x7248;&#x672C;&#x7684;Xcode&#x65F6;&#xFF0C;&#x8FD9;&#x662F;&#x6B63;&#x786E;&#x7684;&#x8DEF;&#x5F84;&#x3002;&#x5982;&#x679C;&#x60A8;&#x9700;&#x8981;&#x4F7F;&#x7528;&#x4E0D;&#x540C;&#x7684;&#x7248;&#x672C;&#xFF0C;&#x8BF7;&#x6307;&#x5B9A;&#x76F8;&#x5E94;&#x8DEF;&#x5F84;&#x3002;</li>
<li>&#x786E;&#x4FDD;Xcode&#x8BB8;&#x53EF;&#x534F;&#x8BAE;&#x662F;&#x901A;&#x8FC7;&#x6253;&#x5F00;&#x4E00;&#x6B21;Xcode&#x6216;&#x901A;&#x8FC7;&#x547D;&#x4EE4;<code>sudo xcodebuild -license</code>&#x540C;&#x610F;&#x8FC7;&#x4E86;.</li>
</ol>
<p>&#x4F7F;&#x7528;Xcode&#xFF0C;&#x60A8;&#x53EF;&#x4EE5;&#x5728;iOS&#x8BBE;&#x5907;&#x6216;&#x6A21;&#x62DF;&#x5668;&#x4E0A;&#x8FD0;&#x884C;Flutter&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x3002;</p>
<h4 id="&#x5B89;&#x88C5;android-studio">&#x5B89;&#x88C5;Android Studio</h4>
<p>&#x548C;Window&#x4E00;&#x6837;&#xFF0C;&#x8981;&#x5728;Android&#x8BBE;&#x5907;&#x4E0A;&#x6784;&#x5EFA;&#x5E76;&#x8FD0;&#x884C;Flutter&#x7A0B;&#x5E8F;&#x90FD;&#x9700;&#x8981;&#x5148;&#x5B89;&#x88C5;Android Studio&#xFF0C;&#x8BFB;&#x8005;&#x53EF;&#x4EE5;&#x5148;&#x81EA;&#x884C;&#x4E0B;&#x8F7D;&#x5E76;&#x5B89;&#x88C5;Android Studio&#xFF0C;&#x5728;&#x6B64;&#x4E0D;&#x518D;&#x8D58;&#x8FF0;&#x3002;</p>
<h3 id="&#x5347;&#x7EA7;-flutter">&#x5347;&#x7EA7; Flutter</h3>
<h4 id="flutter-sdk&#x5206;&#x652F;">Flutter SDK&#x5206;&#x652F;</h4>
<p>Flutter SDK&#x6709;&#x591A;&#x4E2A;&#x5206;&#x652F;&#xFF0C;&#x5982;beta&#x3001;dev&#x3001;master&#x3001;stable&#xFF0C;&#x5176;&#x4E2D;stable&#x5206;&#x652F;&#x4E3A;&#x7A33;&#x5B9A;&#x5206;&#x652F;&#xFF08;&#x65E5;&#x540E;&#x6709;&#x65B0;&#x7684;&#x7A33;&#x5B9A;&#x7248;&#x672C;&#x53D1;&#x5E03;&#x540E;&#x53EF;&#x80FD;&#x4E5F;&#x4F1A;&#x6709;&#x65B0;&#x7684;&#x7A33;&#x5B9A;&#x5206;&#x652F;&#xFF0C;&#x5982;1.0.0&#xFF09;&#xFF0C;dev&#x548C;master&#x4E3A;&#x5F00;&#x53D1;&#x5206;&#x652F;&#xFF0C;&#x5B89;&#x88C5;flutter&#x540E;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x8FD0;&#x884C;<code>flutter channel</code>&#x67E5;&#x770B;&#x6240;&#x6709;&#x5206;&#x652F;&#xFF0C;&#x5982;&#x7B14;&#x8005;&#x672C;&#x5730;&#x8FD0;&#x884C;&#x540E;&#xFF0C;&#x7ED3;&#x679C;&#x5982;&#x4E0B;&#xFF1A;</p>
<pre class="language-"><code>Flutter channels:
  beta
  dev
* master
</code></pre><p>&#x5E26;&quot;*&quot;&#x53F7;&#x7684;&#x5206;&#x652F;&#x5373;&#x4F60;&#x672C;&#x5730;&#x7684;Flutter SDK &#x8DDF;&#x8E2A;&#x7684;&#x5206;&#x652F;&#xFF0C;&#x8981;&#x5207;&#x6362;&#x5206;&#x652F;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;<code>flutter channel beta</code> &#x6216; <code>flutter channel master</code>&#xFF0C;Flutter&#x5B98;&#x65B9;&#x5EFA;&#x8BAE;&#x8DDF;&#x8E2A;&#x7A33;&#x5B9A;&#x5206;&#x652F;&#xFF0C;&#x4F46;&#x4F60;&#x4E5F;&#x53EF;&#x4EE5;&#x8DDF;&#x8E2A;<code>master</code>&#x5206;&#x652F;&#xFF0C;&#x8FD9;&#x6837;&#x53EF;&#x4EE5;&#x67E5;&#x770B;&#x6700;&#x65B0;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x4F46;&#x8FD9;&#x6837;&#x7A33;&#x5B9A;&#x6027;&#x8981;&#x4F4E;&#x7684;&#x591A;&#x3002;</p>
<h4 id="&#x5347;&#x7EA7;flutter-sdk&#x548C;&#x4F9D;&#x8D56;&#x5305;">&#x5347;&#x7EA7;Flutter SDK&#x548C;&#x4F9D;&#x8D56;&#x5305;</h4>
<p>&#x8981;&#x5347;&#x7EA7;flutter sdk&#xFF0C;&#x53EA;&#x9700;&#x4E00;&#x53E5;&#x547D;&#x4EE4;&#xFF1A;</p>
<pre class="language-"><code class="lang-shell">flutter upgrade
</code></pre>
<p>&#x8BE5;&#x547D;&#x4EE4;&#x4F1A;&#x540C;&#x65F6;&#x66F4;&#x65B0;Flutter SDK&#x548C;&#x4F60;&#x7684;flutter&#x9879;&#x76EE;&#x4F9D;&#x8D56;&#x5305;&#x3002;&#x5982;&#x679C;&#x4F60;&#x53EA;&#x60F3;&#x66F4;&#x65B0;&#x9879;&#x76EE;&#x4F9D;&#x8D56;&#x5305;&#xFF08;&#x4E0D;&#x5305;&#x62EC;Flutter SDK&#xFF09;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x5982;&#x4E0B;&#x547D;&#x4EE4;&#xFF1A;</p>
<ul>
<li><code>flutter packages get</code>&#x83B7;&#x53D6;&#x9879;&#x76EE;&#x6240;&#x6709;&#x7684;&#x4F9D;&#x8D56;&#x5305;&#x3002;</li>
<li><code>flutter packages upgrade</code> &#x83B7;&#x53D6;&#x9879;&#x76EE;&#x6240;&#x6709;&#x4F9D;&#x8D56;&#x5305;&#x7684;&#x6700;&#x65B0;&#x7248;&#x672C;&#x3002;</li>
</ul>
<h4 id=""> </h4>
<h2 id="132-ide&#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;">1.3.2 IDE&#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;</h2>
<p>&#x7406;&#x8BBA;&#x4E0A;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4EFB;&#x4F55;&#x6587;&#x672C;&#x7F16;&#x8F91;&#x5668;&#x4E0E;&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;&#x6765;&#x6784;&#x5EFA;Flutter&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x3002; &#x4E0D;&#x8FC7;&#xFF0C;Flutter&#x5B98;&#x65B9;&#x5EFA;&#x8BAE;&#x4F7F;&#x7528;Android Studio&#x548C;VS Code&#x4E4B;&#x4E00;&#x4EE5;&#x83B7;&#x5F97;&#x66F4;&#x597D;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#x3002;Flutter&#x5B98;&#x65B9;&#x63D0;&#x4F9B;&#x4E86;&#x8FD9;&#x4E24;&#x6B3E;&#x7F16;&#x8F91;&#x5668;&#x63D2;&#x4EF6;&#xFF0C;&#x901A;&#x8FC7;IDE&#x548C;&#x63D2;&#x4EF6;&#x53EF;&#x83B7;&#x5F97;&#x4EE3;&#x7801;&#x8865;&#x5168;&#x3001;&#x8BED;&#x6CD5;&#x9AD8;&#x4EAE;&#x3001;widget&#x7F16;&#x8F91;&#x8F85;&#x52A9;&#x3001;&#x8FD0;&#x884C;&#x548C;&#x8C03;&#x8BD5;&#x652F;&#x6301;&#x7B49;&#x529F;&#x80FD;&#xFF0C;&#x53EF;&#x4EE5;&#x5E2E;&#x52A9;&#x6211;&#x4EEC;&#x6781;&#x5927;&#x7684;&#x63D0;&#x9AD8;&#x5F00;&#x53D1;&#x6548;&#x7387;&#x3002;&#x4E0B;&#x9762;&#x6211;&#x4EEC;&#x5206;&#x522B;&#x4ECB;&#x7ECD;&#x4E00;&#x4E0B;Android Studio&#x548C;VS Code&#x7684;&#x914D;&#x7F6E;&#x53CA;&#x4F7F;&#x7528;&#xFF08;Android Studio&#x548C;VS Code&#x8BFB;&#x8005;&#x53EF;&#x4EE5;&#x5728;&#x5176;&#x5B98;&#x7F51;&#x83B7;&#x5F97;&#x6700;&#x65B0;&#x7684;&#x5B89;&#x88C5;&#xFF0C;&#x7531;&#x4E8E;&#x5B89;&#x88C5;&#x6BD4;&#x8F83;&#x7B80;&#x5355;&#xFF0C;&#x6545;&#x4E0D;&#x518D;&#x8D58;&#x8FF0;&#xFF09;&#x3002;</p>
<h3 id="android-studio-&#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;">Android Studio &#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;</h3>
<p>&#x7531;&#x4E8E;Android Studio&#x662F;&#x57FA;&#x4E8E;IntelliJ IDEA&#x5F00;&#x53D1;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x8BFB;&#x8005;&#x4E5F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;IntelliJ IDEA&#x3002;</p>
<h4 id="&#x5B89;&#x88C5;flutter&#x548C;dart&#x63D2;&#x4EF6;">&#x5B89;&#x88C5;Flutter&#x548C;Dart&#x63D2;&#x4EF6;</h4>
<p>&#x9700;&#x8981;&#x5B89;&#x88C5;&#x4E24;&#x4E2A;&#x63D2;&#x4EF6;:</p>
<ul>
<li><code>Flutter</code>&#x63D2;&#x4EF6;&#xFF1A; &#x652F;&#x6301;Flutter&#x5F00;&#x53D1;&#x5DE5;&#x4F5C;&#x6D41; (&#x8FD0;&#x884C;&#x3001;&#x8C03;&#x8BD5;&#x3001;&#x70ED;&#x91CD;&#x8F7D;&#x7B49;)&#x3002;</li>
<li><code>Dart</code>&#x63D2;&#x4EF6;&#xFF1A; &#x63D0;&#x4F9B;&#x4EE3;&#x7801;&#x5206;&#x6790; (&#x8F93;&#x5165;&#x4EE3;&#x7801;&#x65F6;&#x8FDB;&#x884C;&#x9A8C;&#x8BC1;&#x3001;&#x4EE3;&#x7801;&#x8865;&#x5168;&#x7B49;)&#x3002;</li>
</ul>
<p>&#x5B89;&#x88C5;&#x6B65;&#x9AA4;&#xFF1A;</p>
<ol>
<li>&#x542F;&#x52A8;Android Studio&#x3002;</li>
<li>&#x6253;&#x5F00;&#x63D2;&#x4EF6;&#x9996;&#x9009;&#x9879; (macOS&#xFF1A;<strong>Preferences&gt;Plugins</strong>, Windows&#xFF1A;<strong>File&gt;Settings&gt;Plugins</strong>)&#x3002;</li>
<li>&#x9009;&#x62E9; <strong>Browse repositories&#x2026;</strong>&#xFF0C;&#x9009;&#x62E9; flutter &#x63D2;&#x4EF6;&#x5E76;&#x70B9;&#x51FB; <code>install</code>&#x3002;</li>
<li>&#x91CD;&#x542F;Android Studio&#x540E;&#x63D2;&#x4EF6;&#x751F;&#x6548;&#x3002;</li>
</ol>
<p>&#x63A5;&#x4E0B;&#x6765;&#xFF0C;&#x8BA9;&#x6211;&#x4EEC;&#x7528;Android Studio&#x521B;&#x5EFA;&#x4E00;&#x4E2A;Flutter&#x9879;&#x76EE;&#xFF0C;&#x7136;&#x540E;&#x8FD0;&#x884C;&#x5B83;&#xFF0C;&#x5E76;&#x4F53;&#x9A8C;&#x201C;&#x70ED;&#x91CD;&#x8F7D;&#x201D;&#x3002;</p>
<h4 id="&#x521B;&#x5EFA;flutter&#x5E94;&#x7528;">&#x521B;&#x5EFA;Flutter&#x5E94;&#x7528;</h4>
<ol>
<li>&#x9009;&#x62E9; <strong>File&gt;New Flutter Project</strong> &#x3002;</li>
<li>&#x9009;&#x62E9; <strong>Flutter application</strong> &#x4F5C;&#x4E3A; project &#x7C7B;&#x578B;, &#x7136;&#x540E;&#x70B9;&#x51FB; Next&#x3002;</li>
<li>&#x8F93;&#x5165;&#x9879;&#x76EE;&#x540D;&#x79F0; (&#x5982; <code>myapp</code>)&#xFF0C;&#x7136;&#x540E;&#x70B9;&#x51FB; Next&#x3002;</li>
<li>&#x70B9;&#x51FB; <strong>Finish</strong>&#x3002;</li>
<li>&#x7B49;&#x5F85;Android Studio&#x5B89;&#x88C5;SDK&#x5E76;&#x521B;&#x5EFA;&#x9879;&#x76EE;&#x3002;</li>
</ol>
<p>&#x4E0A;&#x8FF0;&#x547D;&#x4EE4;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;Flutter&#x9879;&#x76EE;&#xFF0C;&#x9879;&#x76EE;&#x540D;&#x4E3A;myapp&#xFF0C;&#x5176;&#x4E2D;&#x5305;&#x542B;&#x4E00;&#x4E2A;&#x4F7F;&#x7528;<a href="https://material.io/guidelines/" target="_blank">Material &#x7EC4;&#x4EF6;</a>&#x7684;&#x7B80;&#x5355;&#x6F14;&#x793A;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x3002;</p>
<p>&#x5728;&#x9879;&#x76EE;&#x76EE;&#x5F55;&#x4E2D;&#xFF0C;&#x60A8;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x7684;&#x4EE3;&#x7801;&#x4F4D;&#x4E8E; <code>lib/main.dart</code>&#x3002;</p>
<h4 id="&#x8FD0;&#x884C;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;">&#x8FD0;&#x884C;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;</h4>
<ol>
<li><p>&#x5B9A;&#x4F4D;&#x5230;Android Studio&#x5DE5;&#x5177;&#x680F;&#xFF0C;&#x5982;&#x56FE;1-3&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-3.png" alt="&#x56FE;1-3"></p>
</li>
<li><p>&#x5728; <strong>target selector</strong> &#x4E2D;, &#x9009;&#x62E9;&#x4E00;&#x4E2A;&#x8FD0;&#x884C;&#x8BE5;&#x5E94;&#x7528;&#x7684;Android&#x8BBE;&#x5907;&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x5217;&#x51FA;&#x53EF;&#x7528;&#xFF0C;&#x8BF7;&#x9009;&#x62E9; <strong>Tools&gt;Android&gt;AVD Manager</strong> &#x5E76;&#x5728;&#x90A3;&#x91CC;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x3002;</p>
</li>
<li><p>&#x5728;&#x5DE5;&#x5177;&#x680F;&#x4E2D;&#x70B9;&#x51FB; <strong>Run&#x56FE;&#x6807;</strong>&#x3002;</p>
</li>
<li><p>&#x5982;&#x679C;&#x4E00;&#x5207;&#x6B63;&#x5E38;, &#x60A8;&#x5E94;&#x8BE5;&#x5728;&#x60A8;&#x7684;&#x8BBE;&#x5907;&#x6216;&#x6A21;&#x62DF;&#x5668;&#x4E0A;&#x4F1A;&#x770B;&#x5230;&#x542F;&#x52A8;&#x7684;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-4.png" alt="&#x56FE;1-4"></p>
</li>
</ol>
<h4 id="&#x4F53;&#x9A8C;&#x70ED;&#x91CD;&#x8F7D;">&#x4F53;&#x9A8C;&#x70ED;&#x91CD;&#x8F7D;</h4>
<p>Flutter &#x53EF;&#x4EE5;&#x901A;&#x8FC7; <em>&#x70ED;&#x91CD;&#x8F7D;&#xFF08;hot reload&#xFF09;</em> &#x5B9E;&#x73B0;&#x5FEB;&#x901F;&#x7684;&#x5F00;&#x53D1;&#x5468;&#x671F;&#xFF0C;&#x70ED;&#x91CD;&#x8F7D;&#x5C31;&#x662F;&#x65E0;&#x9700;&#x91CD;&#x542F;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x5C31;&#x80FD;&#x5B9E;&#x65F6;&#x52A0;&#x8F7D;&#x4FEE;&#x6539;&#x540E;&#x7684;&#x4EE3;&#x7801;&#xFF0C;&#x5E76;&#x4E14;&#x4E0D;&#x4F1A;&#x4E22;&#x5931;&#x72B6;&#x6001;&#x3002;&#x7B80;&#x5355;&#x7684;&#x5BF9;&#x4EE3;&#x7801;&#x8FDB;&#x884C;&#x66F4;&#x6539;&#xFF0C;&#x7136;&#x540E;&#x544A;&#x8BC9;IDE&#x6216;&#x547D;&#x4EE4;&#x884C;&#x5DE5;&#x5177;&#x4F60;&#x9700;&#x8981;&#x91CD;&#x65B0;&#x52A0;&#x8F7D;&#xFF08;&#x70B9;&#x51FB;reload&#x6309;&#x94AE;&#xFF09;&#xFF0C;&#x4F60;&#x5C31;&#x4F1A;&#x5728;&#x4F60;&#x7684;&#x8BBE;&#x5907;&#x6216;&#x6A21;&#x62DF;&#x5668;&#x4E0A;&#x770B;&#x5230;&#x66F4;&#x6539;&#x3002;</p>
<ol>
<li>&#x6253;&#x5F00;<code>lib/main.dart</code>&#x6587;&#x4EF6;</li>
<li>&#x5C06;&#x5B57;&#x7B26;&#x4E32;
<code>&apos;You have pushed the button this many times:&apos;</code> &#x66F4;&#x6539;&#x4E3A;
<code>&apos;You have clicked the button this many times:&apos;</code></li>
<li>&#x4E0D;&#x8981;&#x6309;&#x201C;&#x505C;&#x6B62;&#x201D;&#x6309;&#x94AE;; &#x8BA9;&#x60A8;&#x7684;&#x5E94;&#x7528;&#x7EE7;&#x7EED;&#x8FD0;&#x884C;.</li>
<li><p>&#x8981;&#x67E5;&#x66F4;&#x6539;&#xFF0C;&#x8BF7;&#x8C03;&#x7528; <strong>Save</strong> (<code>cmd-s</code> / <code>ctrl-s</code>)&#xFF0C;&#x6216;&#x8005;&#x70B9;&#x51FB; <strong>&#x70ED;&#x91CD;&#x8F7D;&#x6309;&#x94AE;</strong> (&#x5E26;&#x6709;&#x95EA;&#x7535;&#x26A1;&#xFE0F;&#x56FE;&#x6807;&#x7684;&#x6309;&#x94AE;)&#x3002;</p>
<p>&#x4F60;&#x4F1A;&#x7ACB;&#x5373;&#x5728;&#x8FD0;&#x884C;&#x7684;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x4E2D;&#x770B;&#x5230;&#x66F4;&#x65B0;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x3002;</p>
</li>
</ol>
<h3 id="vs-code&#x7684;&#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;">VS Code&#x7684;&#x914D;&#x7F6E;&#x4E0E;&#x4F7F;&#x7528;</h3>
<p>VS Code&#x662F;&#x4E00;&#x4E2A;&#x8F7B;&#x91CF;&#x7EA7;&#x7F16;&#x8F91;&#x5668;&#xFF0C;&#x652F;&#x6301;Flutter&#x8FD0;&#x884C;&#x548C;&#x8C03;&#x8BD5;&#x3002;</p>
<h4 id="&#x5B89;&#x88C5;flutter&#x63D2;&#x4EF6;">&#x5B89;&#x88C5;flutter&#x63D2;&#x4EF6;</h4>
<ol>
<li>&#x542F;&#x52A8; VS Code&#x3002;</li>
<li>&#x8C03;&#x7528; <strong>View&gt;Command Palette&#x2026;</strong>&#x3002;</li>
<li>&#x8F93;&#x5165; &#x2018;install&#x2019;, &#x7136;&#x540E;&#x9009;&#x62E9; <strong>Extensions: Install Extension</strong> action&#x3002;</li>
<li>&#x5728;&#x641C;&#x7D22;&#x6846;&#x8F93;&#x5165; <code>flutter</code> &#xFF0C;&#x5728;&#x641C;&#x7D22;&#x7ED3;&#x679C;&#x5217;&#x8868;&#x4E2D;&#x9009;&#x62E9; &#x2018;Flutter&#x2019;, &#x7136;&#x540E;&#x70B9;&#x51FB; <strong>Install</strong>&#x3002;</li>
<li>&#x9009;&#x62E9; &#x2018;OK&#x2019; &#x91CD;&#x65B0;&#x542F;&#x52A8; VS Code&#x3002;</li>
<li>&#x9A8C;&#x8BC1;&#x914D;&#x7F6E;<ul>
<li>&#x8C03;&#x7528; <strong>View&gt;Command Palette&#x2026;</strong></li>
<li>&#x8F93;&#x5165; &#x2018;doctor&#x2019;, &#x7136;&#x540E;&#x9009;&#x62E9; <strong>&#x2018;Flutter: Run Flutter Doctor&#x2019;</strong> action&#x3002;</li>
<li>&#x67E5;&#x770B;&#x201C;OUTPUT&#x201D;&#x7A97;&#x53E3;&#x4E2D;&#x7684;&#x8F93;&#x51FA;&#x662F;&#x5426;&#x6709;&#x95EE;&#x9898;</li>
</ul>
</li>
</ol>
<h4 id="&#x521B;&#x5EFA;flutter&#x5E94;&#x7528;">&#x521B;&#x5EFA;Flutter&#x5E94;&#x7528;</h4>
<ol>
<li>&#x542F;&#x52A8; VS Code</li>
<li>&#x8C03;&#x7528; <strong>View&gt;Command Palette&#x2026;</strong></li>
<li>&#x8F93;&#x5165; &#x2018;flutter&#x2019;, &#x7136;&#x540E;&#x9009;&#x62E9; <strong>&#x2018;Flutter: New Project&#x2019;</strong> action</li>
<li>&#x8F93;&#x5165; Project &#x540D;&#x79F0; (&#x5982;<code>myapp</code>), &#x7136;&#x540E;&#x6309;&#x56DE;&#x8F66;&#x952E;</li>
<li>&#x6307;&#x5B9A;&#x653E;&#x7F6E;&#x9879;&#x76EE;&#x7684;&#x4F4D;&#x7F6E;&#xFF0C;&#x7136;&#x540E;&#x6309;&#x84DD;&#x8272;&#x7684;&#x786E;&#x5B9A;&#x6309;&#x94AE;</li>
<li>&#x7B49;&#x5F85;&#x9879;&#x76EE;&#x521B;&#x5EFA;&#x7EE7;&#x7EED;&#xFF0C;&#x5E76;&#x663E;&#x793A;main.dart&#x6587;&#x4EF6;</li>
</ol>
<h4 id="&#x4F53;&#x9A8C;&#x70ED;&#x91CD;&#x8F7D;">&#x4F53;&#x9A8C;&#x70ED;&#x91CD;&#x8F7D;</h4>
<ol>
<li>&#x6253;&#x5F00;<code>lib/main.dart</code>&#x6587;&#x4EF6;&#x3002;</li>
<li>&#x5C06;&#x5B57;&#x7B26;&#x4E32;
<code>&apos;You have pushed the button this many times:&apos;</code> &#x66F4;&#x6539;&#x4E3A;
<code>&apos;You have clicked the button this many times:&apos;</code>&#x3002;</li>
<li>&#x4E0D;&#x8981;&#x6309;&#x201C;&#x505C;&#x6B62;&#x201D;&#x6309;&#x94AE;; &#x8BA9;&#x60A8;&#x7684;&#x5E94;&#x7528;&#x7EE7;&#x7EED;&#x8FD0;&#x884C;&#x3002;</li>
<li>&#x8981;&#x67E5;&#x770B;&#x60A8;&#x7684;&#x66F4;&#x6539;&#xFF0C;&#x8BF7;&#x8C03;&#x7528; <strong>Save</strong> (<code>cmd-s</code> / <code>ctrl-s</code>), &#x6216;&#x8005;&#x70B9;&#x51FB; <strong>&#x70ED;&#x91CD;&#x8F7D;&#x6309;&#x94AE;</strong> (&#x7EFF;&#x8272;&#x5706;&#x5F62;&#x7BAD;&#x5934;&#x6309;&#x94AE;)&#x3002;</li>
</ol>
<p>&#x4F60;&#x4F1A;&#x7ACB;&#x5373;&#x5728;&#x8FD0;&#x884C;&#x7684;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x4E2D;&#x770B;&#x5230;&#x66F4;&#x65B0;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x3002;</p>
<h2 id="133-&#x8FDE;&#x63A5;&#x8BBE;&#x5907;&#x8FD0;&#x884C;flutter&#x5E94;&#x7528;">1.3.3 &#x8FDE;&#x63A5;&#x8BBE;&#x5907;&#x8FD0;&#x884C;Flutter&#x5E94;&#x7528;</h2>
<p>Window&#x4E0B;&#x53EA;&#x652F;&#x6301;&#x4E3A;Android&#x8BBE;&#x5907;&#x6784;&#x5EFA;&#x5E76;&#x8FD0;&#x884C;Flutter&#x5E94;&#x7528;&#xFF0C;&#x800C;macOS&#x540C;&#x65F6;&#x652F;&#x6301;iOS&#x548C;Android&#x8BBE;&#x5907;&#x3002;&#x4E0B;&#x9762;&#x5206;&#x522B;&#x4ECB;&#x7ECD;&#x5982;&#x4F55;&#x8FDE;&#x63A5;Android&#x548C;iOS&#x8BBE;&#x5907;&#x6765;&#x8FD0;&#x884C;flutter&#x5E94;&#x7528;&#x3002;</p>
<h3 id="&#x8FDE;&#x63A5;android&#x6A21;&#x62DF;&#x5668;">&#x8FDE;&#x63A5;Android&#x6A21;&#x62DF;&#x5668;</h3>
<p>&#x8981;&#x51C6;&#x5907;&#x5728;Android&#x6A21;&#x62DF;&#x5668;&#x4E0A;&#x8FD0;&#x884C;&#x5E76;&#x6D4B;&#x8BD5;Flutter&#x5E94;&#x7528;&#xFF0C;&#x8BF7;&#x6309;&#x7167;&#x4EE5;&#x4E0B;&#x6B65;&#x9AA4;&#x64CD;&#x4F5C;&#xFF1A;</p>
<ol>
<li><p>&#x542F;&#x52A8; <strong>Android Studio&gt;Tools&gt;Android&gt;AVD Manager</strong> &#x5E76;&#x9009;&#x62E9; <strong>Create Virtual Device</strong>.</p>
</li>
<li><p>&#x9009;&#x62E9;&#x4E00;&#x4E2A;&#x8BBE;&#x5907;&#x5E76;&#x9009;&#x62E9; <strong>Next</strong>&#x3002;</p>
</li>
<li><p>&#x4E3A;&#x8981;&#x6A21;&#x62DF;&#x7684;Android&#x7248;&#x672C;&#x9009;&#x62E9;&#x4E00;&#x4E2A;&#x6216;&#x591A;&#x4E2A;&#x7CFB;&#x7EDF;&#x5370;&#x8C61;&#xFF0C;&#x7136;&#x540E;&#x9009;&#x62E9; <strong>Next</strong>. &#x5EFA;&#x8BAE;&#x4F7F;&#x7528; <em>x86</em> &#x6216; <em>x86_64</em> image .</p>
</li>
<li><p>&#x5728; &#x201C;Emulated Performance&#x201D;&#x4E0B;, &#x9009;&#x62E9; <strong>Hardware - GLES 2.0</strong> &#x4EE5;&#x542F;&#x7528; <a href="https://developer.android.com/studio/run/emulator-acceleration.html" target="_blank">&#x786C;&#x4EF6;&#x52A0;&#x901F;</a>.</p>
</li>
<li><p>&#x9A8C;&#x8BC1;AVD&#x914D;&#x7F6E;&#x662F;&#x5426;&#x6B63;&#x786E;&#xFF0C;&#x7136;&#x540E;&#x9009;&#x62E9; <strong>Finish</strong>&#x3002;</p>
<p>&#x6709;&#x5173;&#x4E0A;&#x8FF0;&#x6B65;&#x9AA4;&#x7684;&#x8BE6;&#x7EC6;&#x4FE1;&#x606F;&#xFF0C;&#x8BF7;&#x53C2;&#x9605; <a href="https://developer.android.com/studio/run/managing-avds.html" target="_blank">Managing AVDs</a>.</p>
</li>
<li><p>&#x5728;&#x201C;Android Virtual Device Manager&#x201D;&#x4E2D;&#xFF0C;&#x70B9;&#x51FB;&#x5DE5;&#x5177;&#x680F;&#x7684; <strong>Run</strong>&#x3002;&#x6A21;&#x62DF;&#x5668;&#x542F;&#x52A8;&#x5E76;&#x663E;&#x793A;&#x6240;&#x9009;&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;&#x7248;&#x672C;&#x6216;&#x8BBE;&#x5907;&#x7684;&#x542F;&#x52A8;&#x753B;&#x9762;&#x3002;</p>
</li>
<li><p>&#x8FD0;&#x884C; <code>flutter run</code> &#x542F;&#x52A8;&#x60A8;&#x7684;&#x8BBE;&#x5907;&#x3002; &#x8FDE;&#x63A5;&#x7684;&#x8BBE;&#x5907;&#x540D;&#x662F; <code>Android SDK built for <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>platform</span><span class="token punctuation">&gt;</span></span></code>&#xFF0C;&#x5176;&#x4E2D; <em>platform</em> &#x662F;&#x82AF;&#x7247;&#x7CFB;&#x5217;&#xFF0C;&#x5982; x86&#x3002;</p>
</li>
</ol>
<h3 id="&#x8FDE;&#x63A5;android&#x771F;&#x673A;&#x8BBE;&#x5907;">&#x8FDE;&#x63A5;Android&#x771F;&#x673A;&#x8BBE;&#x5907;</h3>
<p>&#x8981;&#x51C6;&#x5907;&#x5728;Android&#x8BBE;&#x5907;&#x4E0A;&#x8FD0;&#x884C;&#x5E76;&#x6D4B;&#x8BD5;Flutter&#x5E94;&#x7528;&#xFF0C;&#x9700;&#x8981;Android 4.1&#xFF08;API level 16&#xFF09;&#x6216;&#x66F4;&#x9AD8;&#x7248;&#x672C;&#x7684;Android&#x8BBE;&#x5907;.</p>
<ol>
<li>&#x5728;Android&#x8BBE;&#x5907;&#x4E0A;&#x542F;&#x7528; <strong>&#x5F00;&#x53D1;&#x4EBA;&#x5458;&#x9009;&#x9879;</strong> &#x548C; <strong>USB&#x8C03;&#x8BD5;</strong> &#x3002;&#x8BE6;&#x7EC6;&#x8BF4;&#x660E;&#x53EF;&#x5728;<a href="https://developer.android.com/studio/debug/dev-options.html" target="_blank">Android&#x6587;&#x6863;</a>&#x4E2D;&#x627E;&#x5230;&#x3002;</li>
<li>&#x4F7F;&#x7528;USB&#x5C06;&#x624B;&#x673A;&#x63D2;&#x5165;&#x7535;&#x8111;&#x3002;&#x5982;&#x679C;&#x8BBE;&#x5907;&#x51FA;&#x73B0;&#x8C03;&#x8BD5;&#x6388;&#x6743;&#x63D0;&#x793A;&#xFF0C;&#x8BF7;&#x6388;&#x6743;&#x4F60;&#x7684;&#x7535;&#x8111;&#x53EF;&#x4EE5;&#x8BBF;&#x95EE;&#x8BE5;&#x8BBE;&#x5907;&#x3002;</li>
<li>&#x5728;&#x547D;&#x4EE4;&#x884C;&#x8FD0;&#x884C; <code>flutter devices</code> &#x547D;&#x4EE4;&#x4EE5;&#x9A8C;&#x8BC1;Flutter&#x8BC6;&#x522B;&#x60A8;&#x8FDE;&#x63A5;&#x7684;Android&#x8BBE;&#x5907;&#x3002;</li>
<li>&#x8FD0;&#x884C;&#x542F;&#x52A8;&#x4F60;&#x5E94;&#x7528;&#x7A0B;&#x5E8F; <code>flutter run</code>&#x3002;</li>
</ol>
<p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;Flutter&#x4F7F;&#x7528;&#x7684;Android SDK&#x7248;&#x672C;&#x662F;&#x57FA;&#x4E8E;&#x4F60;&#x7684; <code>adb</code> &#x5DE5;&#x5177;&#x7248;&#x672C;&#x3002; &#x5982;&#x679C;&#x60F3;&#x8BA9;Flutter&#x4F7F;&#x7528;&#x4E0D;&#x540C;&#x7248;&#x672C;&#x7684;Android SDK&#xFF0C;&#x5219;&#x5FC5;&#x987B;&#x5C06;&#x8BE5; <code>ANDROID_HOME</code> &#x73AF;&#x5883;&#x53D8;&#x91CF;&#x8BBE;&#x7F6E;&#x4E3A;&#x76F8;&#x5E94;&#x7684;SDK&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x3002;</p>
<h3 id="&#x8FDE;&#x63A5;ios&#x6A21;&#x62DF;&#x5668;">&#x8FDE;&#x63A5;iOS&#x6A21;&#x62DF;&#x5668;</h3>
<p>&#x8981;&#x51C6;&#x5907;&#x5728;iOS&#x6A21;&#x62DF;&#x5668;&#x4E0A;&#x8FD0;&#x884C;&#x5E76;&#x6D4B;&#x8BD5;Flutter&#x5E94;&#x7528;&#xFF0C;&#x8BF7;&#x6309;&#x4EE5;&#x4E0B;&#x6B65;&#x9AA4;&#x64CD;&#x4F5C;&#xFF1A;</p>
<ol>
<li><p>&#x5728;&#x4F60;&#x7684;MAC&#x4E0A;&#xFF0C;&#x901A;&#x8FC7; Spotlight &#x6216;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x627E;&#x5230;&#x6A21;&#x62DF;&#x5668;&#xFF1A;</p>
<pre class="language-"><code class="lang-shell"><span class="token function">open</span> -a Simulator
</code></pre>
</li>
<li><p>&#x901A;&#x8FC7;&#x68C0;&#x67E5;&#x6A21;&#x62DF;&#x5668; <strong>Hardware &gt; Device</strong> &#x83DC;&#x5355;&#x4E2D;&#x7684;&#x8BBE;&#x7F6E;&#xFF0C;&#x786E;&#x4FDD;&#x6A21;&#x62DF;&#x5668;&#x6B63;&#x5728;&#x4F7F;&#x7528;64&#x4F4D;&#x8BBE;&#x5907;&#xFF08;iPhone 5s&#x6216;&#x66F4;&#x9AD8;&#x7248;&#x672C;&#xFF09;&#x3002;</p>
</li>
<li><p>&#x6839;&#x636E;&#x4F60;&#x7535;&#x8111;&#x5C4F;&#x5E55;&#x5927;&#x5C0F;&#xFF0C;&#x6A21;&#x62DF;&#x9AD8;&#x6E05;&#x5C4F;iOS&#x8BBE;&#x5907;&#x53EF;&#x80FD;&#x4F1A;&#x6EA2;&#x51FA;&#x5C4F;&#x5E55;&#x3002;&#x53EF;&#x4EE5;&#x5728;&#x6A21;&#x62DF;&#x5668;&#x7684; <strong>Window&gt; Scale</strong> &#x83DC;&#x5355;&#x4E0B;&#x8BBE;&#x7F6E;&#x8BBE;&#x5907;&#x6BD4;&#x4F8B;&#x3002;</p>
</li>
<li><p>&#x8FD0;&#x884C; <code>flutter run</code>&#x542F;&#x52A8;flutter&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x3002;</p>
</li>
</ol>
<h3 id="&#x8FDE;&#x63A5;ios&#x771F;&#x673A;&#x8BBE;&#x5907;">&#x8FDE;&#x63A5;iOS&#x771F;&#x673A;&#x8BBE;&#x5907;</h3>
<p>&#x8981;&#x5C06;Flutter&#x5E94;&#x7528;&#x5B89;&#x88C5;&#x5230;iOS&#x771F;&#x673A;&#x8BBE;&#x5907;&#xFF0C;&#x9700;&#x8981;&#x4E00;&#x4E9B;&#x989D;&#x5916;&#x7684;&#x5DE5;&#x5177;&#x548C;&#x4E00;&#x4E2A;Apple&#x5E10;&#x6237;&#xFF0C;&#x8FD8;&#x9700;&#x8981;&#x5728;Xcode&#x4E2D;&#x8FDB;&#x884C;&#x4E00;&#x4E9B;&#x8BBE;&#x7F6E;&#x3002;</p>
<ol>
<li><p>&#x5B89;&#x88C5; <a href="http://brew.sh/" target="_blank">homebrew</a> &#xFF08;&#x5982;&#x679C;&#x5DF2;&#x7ECF;&#x5B89;&#x88C5;&#x4E86;brew,&#x8DF3;&#x8FC7;&#x6B64;&#x6B65;&#x9AA4;&#xFF09;&#x3002;</p>
</li>
<li><p>&#x6253;&#x5F00;&#x7EC8;&#x7AEF;&#x5E76;&#x8FD0;&#x884C;&#x5982;&#x4E0B;&#x8FD9;&#x4E9B;&#x547D;&#x4EE4;:</p>
<pre class="language-"><code class="lang-shell">brew update
brew <span class="token function">install</span> --HEAD libimobiledevice
brew <span class="token function">install</span> ideviceinstaller ios-deploy cocoapods
pod setup
</code></pre>
<p>&#x5982;&#x679C;&#x8FD9;&#x4E9B;&#x547D;&#x4EE4;&#x4E2D;&#x7684;&#x4EFB;&#x4F55;&#x4E00;&#x4E2A;&#x5931;&#x8D25;&#x5E76;&#x51FA;&#x73B0;&#x9519;&#x8BEF;&#xFF0C;&#x8BF7;&#x8FD0;&#x884C;brew doctor&#x5E76;&#x6309;&#x7167;&#x8BF4;&#x660E;&#x89E3;&#x51B3;&#x95EE;&#x9898;.</p>
</li>
<li><p>&#x9075;&#x5FAA;Xcode&#x7B7E;&#x540D;&#x6D41;&#x7A0B;&#x6765;&#x914D;&#x7F6E;&#x60A8;&#x7684;&#x9879;&#x76EE;:</p>
<ul>
<li><p>&#x5728;&#x4F60;Flutter&#x9879;&#x76EE;&#x76EE;&#x5F55;&#x4E2D;&#x901A;&#x8FC7; <code>open ios/Runner.xcworkspace</code> &#x6253;&#x5F00;&#x9ED8;&#x8BA4;&#x7684;Xcode workspace.</p>
</li>
<li><p>&#x5728;Xcode&#x4E2D;&#xFF0C;&#x9009;&#x62E9;&#x5BFC;&#x822A;&#x9762;&#x677F;&#x5DE6;&#x4FA7;&#x4E2D;&#x7684;<code>Runner</code>&#x9879;&#x76EE;&#x3002;</p>
</li>
<li><p>&#x5728;<code>Runner</code> target&#x8BBE;&#x7F6E;&#x9875;&#x9762;&#x4E2D;&#xFF0C;&#x786E;&#x4FDD;&#x5728; <strong>General &gt; Signing &gt; Team</strong> &#x4E0B;&#x9009;&#x62E9;&#x4E86;&#x4F60;&#x7684;&#x5F00;&#x53D1;&#x56E2;&#x961F;&#x3002;&#x5F53;&#x4F60;&#x9009;&#x62E9;&#x4E00;&#x4E2A;&#x56E2;&#x961F;&#x65F6;&#xFF0C;Xcode&#x4F1A;&#x521B;&#x5EFA;&#x5E76;&#x4E0B;&#x8F7D;&#x5F00;&#x53D1;&#x8BC1;&#x4E66;&#xFF0C;&#x5411;&#x4F60;&#x7684;&#x8BBE;&#x5907;&#x6CE8;&#x518C;&#x4F60;&#x7684;&#x5E10;&#x6237;&#xFF0C;&#x5E76;&#x521B;&#x5EFA;&#x548C;&#x4E0B;&#x8F7D;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#xFF08;&#x5982;&#x679C;&#x9700;&#x8981;&#xFF09;&#x3002;</p>
</li>
<li><p>&#x8981;&#x5F00;&#x59CB;&#x60A8;&#x7684;&#x7B2C;&#x4E00;&#x4E2A;iOS&#x5F00;&#x53D1;&#x9879;&#x76EE;&#xFF0C;&#x60A8;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x4F7F;&#x7528;&#x60A8;&#x7684;Apple ID&#x767B;&#x5F55;Xcode&#xFF0C;&#x5982;&#x56FE;1-5&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-5.png" alt="&#x56FE;1-5"></p>
<p>&#x4EFB;&#x4F55;Apple ID&#x90FD;&#x652F;&#x6301;&#x5F00;&#x53D1;&#x548C;&#x6D4B;&#x8BD5;&#xFF0C;&#x4F46;&#x82E5;&#x60F3;&#x5C06;&#x5E94;&#x7528;&#x5206;&#x53D1;&#x5230;App Store&#xFF0C;&#x5C31;&#x5FC5;&#x987B;&#x6CE8;&#x518C;Apple&#x5F00;&#x53D1;&#x8005;&#x8BA1;&#x5212;&#xFF0C;&#x6709;&#x5173;&#x8BE6;&#x60C5;&#x8BFB;&#x8005;&#x53EF;&#x4EE5;&#x81EA;&#x884C;&#x4E86;&#x89E3;&#x3002;</p>
</li>
<li><p>&#x5F53;&#x60A8;&#x7B2C;&#x4E00;&#x6B21;attach&#x771F;&#x673A;&#x8BBE;&#x5907;&#x8FDB;&#x884C;iOS&#x5F00;&#x53D1;&#x65F6;&#xFF0C;&#x9700;&#x8981;&#x540C;&#x65F6;&#x4FE1;&#x4EFB;&#x4F60;&#x7684;Mac&#x548C;&#x8BE5;&#x8BBE;&#x5907;&#x4E0A;&#x7684;&#x5F00;&#x53D1;&#x8BC1;&#x4E66;&#x3002;&#x9996;&#x6B21;&#x5C06;iOS&#x8BBE;&#x5907;&#x8FDE;&#x63A5;&#x5230;Mac&#x65F6;&#xFF0C;&#x8BF7;&#x5728;&#x5BF9;&#x8BDD;&#x6846;&#x4E2D;&#x9009;&#x62E9; <code>Trust</code>&#x3002; </p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-6.png" alt="&#x6DFB;&#x52A0;&#x4FE1;&#x4EFB;"></p>
<p>&#x7136;&#x540E;&#xFF0C;&#x8F6C;&#x5230;iOS&#x8BBE;&#x5907;&#x4E0A;&#x7684;<strong>&#x8BBE;&#x7F6E;</strong>&#x83DC;&#x5355;&#xFF0C;&#x9009;&#x62E9; <strong>&#x5E38;&#x89C4;&gt;&#x8BBE;&#x5907;&#x7BA1;&#x7406;</strong> &#x5E76;&#x4FE1;&#x4EFB;&#x60A8;&#x7684;&#x8BC1;&#x4E66;&#x3002;</p>
</li>
<li><p>&#x5982;&#x679C;Xcode&#x4E2D;&#x7684;&#x81EA;&#x52A8;&#x7B7E;&#x540D;&#x5931;&#x8D25;&#xFF0C;&#x8BF7;&#x9A8C;&#x8BC1;&#x9879;&#x76EE;&#x7684; <strong>General &gt; Identity &gt; Bundle Identifier</strong> &#x503C;&#x662F;&#x5426;&#x552F;&#x4E00;&#xFF0C;&#x5982;&#x56FE;1-7&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-7.png" alt="&#x9A8C;&#x8BC1;bundle id&#x662F;&#x5426;&#x552F;&#x4E00;"></p>
</li>
<li><p>&#x8FD0;&#x884C; <code>flutter run</code>&#x542F;&#x52A8;flutter&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x3002;</p>
</li>
</ul>
</li>
</ol>
<h2 id="134-&#x5E38;&#x89C1;&#x914D;&#x7F6E;&#x95EE;&#x9898;">1.3.4 &#x5E38;&#x89C1;&#x914D;&#x7F6E;&#x95EE;&#x9898;</h2>
<h3 id="android-studio&#x95EE;&#x9898;">Android Studio&#x95EE;&#x9898;</h3>
<h4 id="&#x7F3A;&#x5C11;&#x4F9D;&#x8D56;&#x5E93;&#x95EE;&#x9898;">&#x7F3A;&#x5C11;&#x4F9D;&#x8D56;&#x5E93;&#x95EE;&#x9898;</h4>
<p>&#x4E0A;&#x624B;&#x5B89;&#x5353;&#x6700;&#x5E38;&#x9047;&#x89C1;&#x7684;&#x95EE;&#x9898;&#x4E4B;&#x4E00;&#xFF0C;&#x9519;&#x8BEF;&#x5982;&#x56FE;1-8&#x6240;&#x793A;&#xFF0C;&#x6B64;&#x65F6;&#x70B9;&#x51FB;&#x8D85;&#x94FE;&#x63A5;&#x5373;&#x53EF;&#x81EA;&#x52A8;&#x8DF3;&#x8F6C;&#x5230;&#x5B89;&#x88C5;&#x9875;&#x9762;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-8.png" alt="&#x56FE;1-8"></p>
<p>&#x5B89;&#x88C5;&#x4E4B;&#x540E;&#x91CD;&#x65B0;&#x8FD0;&#x884C;&#x5373;&#x53EF;&#xFF0C;&#x5982;&#x56FE;1-9&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-9.png" alt="install_request_components.png"></p>
<h4 id="&#x8FDE;&#x63A5;&#x4E0D;&#x4E0A;android-repository">&#x8FDE;&#x63A5;&#x4E0D;&#x4E0A;Android Repository</h4>
<p>&#x8FD9;&#x4E5F;&#x662F;&#x6700;&#x5E38;&#x89C1;&#x7684;&#x95EE;&#x9898;&#x4E4B;&#x4E00;&#xFF0C;&#x5F53;&#x4F60;&#x53D1;&#x73B0;&#x81EA;&#x5DF1;&#x65E0;&#x6CD5;&#x4E0B;&#x8F7D;&#x90E8;&#x5206;&#x4F9D;&#x8D56;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x8BF7;&#x4F18;&#x5148;&#x8003;&#x8651;&#x8FD9;&#x79CD;&#x60C5;&#x51B5;&#x3002;&#x8FDB;&#x5165; <code>File</code> -&gt; <code>Settings</code> -&gt; <code>Appearance &amp; Behavior</code> -&gt; <code>System Settings</code> -&gt; <code>Android SDK</code> -&gt; <code>SDK Update Sites</code> &#x5217;&#x8868;&#xFF0C;&#x53EF;&#x4EE5;&#x770B;&#x5230;&#x6B64;&#x65F6;&#x7684; <code>Android Repository</code> &#x65E0;&#x6CD5;&#x8FDE;&#x63A5;&#xFF0C;&#x5982;&#x56FE;1-10&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="https://pcdn.flutterchina.club/imgs/1-10.png" alt="&#x4E0B;&#x8F7D;&#x4F9D;&#x8D56;&#x5931;&#x8D25;"></p>
<p>&#x8FD9;&#x662F;&#x7531;&#x4E8E;&#x8981;&#x53BB;Google&#x4E0B;&#x8F7D;Android SDK&#xFF0C;&#x4F46;&#x5728;&#x56FD;&#x5185;&#x76EE;&#x524D;&#x65E0;&#x6CD5;&#x8BBF;&#x95EE;Google&#x6240;&#x81F4;&#xFF0C;&#x56E0;&#x6B64;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x914D;&#x7F6E;&#x4EE3;&#x7406;&#x6216;&#x4F7F;&#x7528;vpn&#x3002;</p>
<h4 id="&#x5B89;&#x5353;&#x5305;&#x914D;&#x7F6E;&#x95EE;&#x9898;">&#x5B89;&#x5353;&#x5305;&#x914D;&#x7F6E;&#x95EE;&#x9898;</h4>
<p>&#x4E00;&#x822C;&#x683C;&#x5F0F;&#x4E3A;</p>
<pre class="language-"><code>Could not HEAD **
Could not Get **
</code></pre><p>&#x5982;&#xFF1A;<code>Android Studio Could not GET gradle-3.2.0.pom</code></p>
<p>&#x8FD9;&#x4E00;&#x7C7B;&#x95EE;&#x9898;&#x662F;&#x7531;&#x4E8E;&#x65E0;&#x6CD5;&#x8FDE;&#x63A5;&#x5230; Maven &#x5E93;&#x9020;&#x6210;&#x7684;&#xFF0C;&#x89E3;&#x51B3;&#x65B9;&#x6CD5;&#x5982;&#x4E0B;&#xFF1A;</p>
<ol>
<li><p>&#x8FDB;&#x5165;<code>&#x5F53;&#x524D;&#x6240;&#x5728;&#x9879;&#x76EE;&#x540D;/android</code></p>
</li>
<li><p>&#x6253;&#x5F00; <code>build.gradle</code> </p>
</li>
<li><p>&#x627E;&#x5230;&#x4E0B;&#x9762;&#x8FD9;&#x4E00;&#x90E8;&#x5206;&#xFF0C;&#x5E76;&#x52A0;&#x4E0A; <code>maven { url &apos;http://maven.aliyun.com/nexus/content/groups/public/&apos; }</code> </p>
<pre class="language-"><code>allprojects {
    repositories {
      google()
      jcenter()
      maven { url &apos;http://maven.aliyun.com/nexus/content/groups/public/&apos; } //&#x6DFB;&#x52A0;&#x8FD9;&#x4E00;&#x53E5;
    }
}
</code></pre></li>
<li><p>&#x8FDB;&#x5165; File/ Settings/ Build, Execution, Deployment/ BuildTools/ Gradle/ Android Studio &#x4E2D;&#xFF0C;&#x52FE;&#x9009;&#x4E0A; Enable embedded Maven repository &#xFF0C;&#x91CD;&#x542F; Android Studio &#x5373;&#x53EF;&#x89E3;&#x51B3;&#x3002;</p>
<blockquote>
<p><strong>&#x6CE8;&#x610F;&#xFF1A;</strong>&#x5B58;&#x5728;&#x8FD9;&#x6837;&#x7684;&#x4E00;&#x79CD;&#x60C5;&#x51B5;&#xFF0C;&#x5F53;&#x4F60;&#x6839;&#x636E;&#x4E0A;&#x8FF0;&#x6B65;&#x9AA4;&#x8BBE;&#x7F6E;&#x4E86;&#x4E4B;&#x540E;&#xFF0C;&#x4F9D;&#x65E7;&#x65E0;&#x6CD5;&#x89E3;&#x51B3;&#x8FD9;&#x4E2A;&#x95EE;&#x9898;&#xFF0C;&#x5E76;&#x6709;&#x7C7B;&#x4F3C;&#x4E8E; <code>Could not HEAD maven.aliyun.com</code> &#x7684;&#x62A5;&#x9519;&#x4FE1;&#x606F;&#xFF0C;&#x8BF7;&#x68C0;&#x67E5; <code>C:\Users\{user_name}\.gradle\gradle.properties</code> &#x662F;&#x5426;&#x6709;&#x8BBE;&#x7F6E;&#x4EE3;&#x7406;&#x3002;&#x5220;&#x9664;&#x540E;&#x95EE;&#x9898;&#x5373;&#x53EF;&#x89E3;&#x51B3;&#x3002;</p>
</blockquote>
</li>
</ol>
<h4 id="hot-reload-&#x70ED;&#x91CD;&#x8F7D;&#x5931;&#x6548;&#x95EE;&#x9898;">Hot Reload &#x70ED;&#x91CD;&#x8F7D;&#x5931;&#x6548;&#x95EE;&#x9898;</h4>
<p>&#x5728;&#x7ED9; <code>Terminal</code> &#x4E4B;&#x7C7B;&#x7684;&#x7EC8;&#x7AEF;&#x6A21;&#x62DF;&#x5668;&#x8BBE;&#x7F6E;&#x4EE3;&#x7406;&#x4E4B;&#x540E;&#xFF0C;&#x4F1A;&#x5BFC;&#x81F4;&#x201C;Hot Reload&#x201D;&#x91CD;&#x8F7D;&#x5931;&#x6548;&#xFF0C;&#x6B64;&#x65F6;&#x8C03;&#x7528; <strong>Save</strong> (<code>cmd-s</code> / <code>ctrl-s</code>)&#x5C06;&#x4E0D;&#x4F1A;&#x8FDB;&#x884C;&#x70ED;&#x91CD;&#x8F7D;&#xFF0C;<strong>&#x70ED;&#x91CD;&#x8F7D;&#x6309;&#x94AE;</strong> (&#x5E26;&#x6709;&#x95EA;&#x7535;&#x26A1;&#xFE0F;&#x56FE;&#x6807;&#x7684;&#x6309;&#x94AE;)&#x4E5F;&#x4E0D;&#x4F1A;&#x663E;&#x793A;&#xFF0C;&#x5C06;&#x4EE3;&#x7406;&#x79FB;&#x9664;&#x5373;&#x53EF;&#x89E3;&#x51B3;&#x3002;</p>
<p>&#x53E6;&#x5916;&#xFF0C;&#x6709;&#x4E9B;&#x60C5;&#x51B5;&#x4E0B;&#x70ED;&#x91CD;&#x8F7D;&#x662F;&#x4E0D;&#x751F;&#x6548;&#x7684;&#xFF0C;&#x6BD4;&#x5982;&#x4FEE;&#x6539;&#x4E86;<code>main</code>&#x51FD;&#x6570;&#x3001;&#x4FEE;&#x6539;&#x4E86;&#x5168;&#x5C40;&#x9759;&#x6001;&#x65B9;&#x6CD5;&#x7B49;&#xFF0C;&#x8BFB;&#x8005;&#x53EF;&#x4EE5;&#x8BA4;&#x4E3A;&#x201C;Hot Reload&#x201D;&#x53EA;&#x4F1A;&#x91CD;&#x65B0;&#x6784;&#x5EFA;&#x6574;&#x4E2A;widget&#x6811;&#xFF0C;&#x5982;&#x679C;&#x53D8;&#x52A8;&#x4E0D;&#x5728;&#x6784;&#x5EFA;widget&#x6811;&#x7684;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x201C;Hot Reload&#x201D;&#x5C31;&#x4E0D;&#x4F1A;&#x8D77;&#x4F5C;&#x7528;&#x3002;</p>

                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="flutter_intro.html" class="navigation navigation-prev " aria-label="Previous page: 1.2：初识Flutter">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
                <a href="dart.html" class="navigation navigation-next " aria-label="Next page: 1.4：Dart语言简介">
                    <i class="fa fa-angle-right"></i>
                </a>
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"1.3：搭建Flutter开发环境","level":"2.1.3","depth":2,"next":{"title":"1.4：Dart语言简介","level":"2.1.4","depth":2,"path":"chapter1/dart.md","ref":"chapter1/dart.md","articles":[]},"previous":{"title":"1.2：初识Flutter","level":"2.1.2","depth":2,"path":"chapter1/flutter_intro.md","ref":"chapter1/flutter_intro.md","articles":[]},"dir":"ltr"},"config":{"plugins":["-search","search-pro","ace","splitter","prism","donate","-highlight"],"root":"docs","styles":{"website":"styles/website.css","ebook":"styles/ebook.css","pdf":"styles/pdf.css","mobi":"styles/mobi.css","epub":"styles/epub.css"},"pluginsConfig":{"prism":{"lang":{"shell":"bash"}},"ace":{},"splitter":{},"search-pro":{"cutWordLib":"nodejieba","defineWord":["Gitbook Use"]},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"donate":{"alipay":"","alipayText":"支付宝打赏","button":"赏","title":"","wechat":"https://pcdn.flutterchina.club/imgs/pay.jpeg","wechatText":"微信打赏"},"fontsettings":{"theme":"white","family":"sans","size":2},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","author":"wendux 824783146@qq.com","bookRoot":"https://book.flutterchina.club/","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"《Flutter实战》","language":"zh-hans","links":{"sharing":{"all":null,"facebook":null,"google":null,"twitter":null,"weibo":null},"sidebar":{"<div><img height=20 style='position:relative; top:5px; padding-right:5px ' src='https://cdn.jsdelivr.net/gh/flutterchina/website@1.0/images/favicon.png'/> Flutter中文网</div>":"https://flutterchina.club"}},"gitbook":"*","description":"记录Gitbook的配置和一些插件的使用"},"file":{"path":"chapter1/install_flutter.md","mtime":"2019-11-25T08:32:52.234Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-05-05T06:01:05.405Z"},"basePath":"..","book":{"language":""}});
        });
    </script>
</div>



    <script src="https://pcdn.flutterchina.club/gitbook/gitbook.js"></script>
    <script src="https://pcdn.flutterchina.club/gitbook/theme.js"></script>
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-search-pro/search.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-ace/ace/ace.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-ace/ace.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-donate/plugin.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="https://pcdn.flutterchina.club/gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    


<script src="https://pcdn.flutterchina.club/gitbook/pub.js"></script>
</body>

</html>

